ALTER TABLE pgivm.pg_ivm_immv ADD COLUMN querystring text NOT NULL; 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 $$; CREATE FUNCTION pgivm.save_query_strings() RETURNS event_trigger AS 'MODULE_PATHNAME', 'save_query_strings' LANGUAGE C; CREATE FUNCTION pgivm.restore_query_strings() RETURNS event_trigger AS 'MODULE_PATHNAME', 'restore_query_strings' LANGUAGE C; CREATE EVENT TRIGGER save_query_strings ON ddl_command_start EXECUTE FUNCTION pgivm.save_query_strings(); CREATE EVENT TRIGGER restore_query_strings ON ddl_command_end EXECUTE FUNCTION pgivm.restore_query_strings();