2025-03-26 18:32:09 +00:00
|
|
|
ALTER TABLE pgivm.pg_ivm_immv ADD COLUMN querystring text NOT NULL;
|
2025-05-19 16:22:52 +00:00
|
|
|
ALTER TABLE pgivm.pg_ivm_immv ADD COLUMN immvuuid uuid NOT NULL;
|
|
|
|
|
ALTER TABLE pgivm.pg_ivm_immv ADD CONSTRAINT pg_ivm_immv_uuid UNIQUE (immvuuid);
|
2025-03-26 17:20:36 +00:00
|
|
|
|
2025-03-26 22:44:45 +00:00
|
|
|
CREATE FUNCTION pgivm.recreate_all_immvs() RETURNS VOID LANGUAGE PLPGSQL AS
|
|
|
|
|
$$
|
|
|
|
|
BEGIN
|
|
|
|
|
PERFORM pgivm.refresh_immv(n.nspname || '.' || c.relname, false)
|
|
|
|
|
FROM pgivm.pg_ivm_immv as ivm
|
|
|
|
|
JOIN pg_catalog.pg_class as c
|
|
|
|
|
ON c.oid = ivm.immvrelid
|
|
|
|
|
JOIN pg_catalog.pg_namespace as n
|
|
|
|
|
ON c.relnamespace = n.oid;
|
|
|
|
|
|
|
|
|
|
PERFORM pgivm.refresh_immv(n.nspname || '.' || c.relname, true)
|
|
|
|
|
FROM pgivm.pg_ivm_immv as ivm
|
|
|
|
|
JOIN pg_catalog.pg_class as c
|
|
|
|
|
ON c.oid = ivm.immvrelid
|
|
|
|
|
JOIN pg_catalog.pg_namespace as n
|
|
|
|
|
ON c.relnamespace = n.oid;
|
|
|
|
|
END
|
|
|
|
|
$$;
|
|
|
|
|
|
2025-05-20 19:16:55 +00:00
|
|
|
CREATE FUNCTION pgivm.save_query_strings() RETURNS event_trigger
|
|
|
|
|
AS 'MODULE_PATHNAME', 'save_query_strings' LANGUAGE C;
|
2025-03-26 17:20:36 +00:00
|
|
|
|
2025-05-20 19:16:55 +00:00
|
|
|
CREATE FUNCTION pgivm.restore_query_strings() RETURNS event_trigger
|
|
|
|
|
AS 'MODULE_PATHNAME', 'restore_query_strings' LANGUAGE C;
|
2025-03-26 17:20:36 +00:00
|
|
|
|
2025-05-20 19:16:55 +00:00
|
|
|
CREATE EVENT TRIGGER save_query_strings
|
|
|
|
|
ON ddl_command_start
|
|
|
|
|
EXECUTE FUNCTION pgivm.save_query_strings();
|
2025-03-26 17:20:36 +00:00
|
|
|
|
2025-05-20 19:16:55 +00:00
|
|
|
CREATE EVENT TRIGGER restore_query_strings
|
2025-03-26 17:20:36 +00:00
|
|
|
ON ddl_command_end
|
2025-05-20 19:16:55 +00:00
|
|
|
EXECUTE FUNCTION pgivm.restore_query_strings();
|