pg_ivm/pg_ivm--1.10.sql
2025-03-11 18:49:53 +00:00

81 lines
2 KiB
SQL

DO $$
DECLARE
shared_pl text;
session_pl text;
BEGIN
SELECT setting INTO shared_pl FROM pg_catalog.pg_settings
WHERE name = 'shared_preload_libraries';
SELECT setting INTO session_pl FROM pg_catalog.pg_settings
WHERE name = 'session_preload_libraries';
IF shared_pl !~ '\mpg_ivm\M' AND session_pl !~ '\mpg_ivm\M' THEN
RAISE EXCEPTION 'pg_ivm is not loaded in shared_preload_libraries '
'or session_preload_libraries'
USING HINT = 'Add pg_ivm to session_preload_libraries and '
'restart the session. Or, add pg_ivm to '
'shared_preload_libraries and restart Postgres.';
END IF;
END
$$;
CREATE SCHEMA pgivm;
-- catalog
CREATE TABLE pgivm.pg_ivm_immv(
immvrelid regclass NOT NULL,
viewdef text NOT NULL,
ispopulated bool NOT NULL,
lastivmupdate xid8,
CONSTRAINT pg_ivm_immv_pkey PRIMARY KEY (immvrelid)
);
SELECT pg_catalog.pg_extension_config_dump('pgivm.pg_ivm_immv', '');
-- functions
CREATE FUNCTION pgivm.create_immv(text, text)
RETURNS bigint
STRICT
AS 'MODULE_PATHNAME', 'create_immv'
LANGUAGE C;
CREATE FUNCTION pgivm.refresh_immv(text, bool)
RETURNS bigint
STRICT
AS 'MODULE_PATHNAME', 'refresh_immv'
LANGUAGE C;
CREATE FUNCTION pgivm.get_immv_def(IN immvrelid regclass)
RETURNS text
STRICT
AS 'MODULE_PATHNAME', 'get_immv_def'
LANGUAGE C;
CREATE FUNCTION pgivm.ivm_visible_in_prestate(oid, tid, oid)
RETURNS bool
STABLE
AS 'MODULE_PATHNAME', 'ivm_visible_in_prestate'
LANGUAGE C;
-- trigger functions
CREATE FUNCTION pgivm."IVM_immediate_before"()
RETURNS trigger
AS 'MODULE_PATHNAME', 'IVM_immediate_before'
LANGUAGE C;
CREATE FUNCTION pgivm."IVM_immediate_maintenance"()
RETURNS trigger
AS 'MODULE_PATHNAME', 'IVM_immediate_maintenance'
LANGUAGE C;
CREATE FUNCTION pgivm."IVM_prevent_immv_change"()
RETURNS trigger
AS 'MODULE_PATHNAME', 'IVM_prevent_immv_change'
LANGUAGE C;
GRANT SELECT ON TABLE pgivm.pg_ivm_immv TO PUBLIC;
GRANT USAGE ON SCHEMA pgivm TO PUBLIC;