/*------------------------------------------------------------------------- * * pg_ivm.h * incremental view maintenance extension * * Portions Copyright (c) 1996-2022, PostgreSQL Global Development Group * Portions Copyright (c) 2022, IVM Development Group * *------------------------------------------------------------------------- */ #ifndef _PG_IVM_H_ #define _PG_IVM_H_ #include "catalog/objectaddress.h" #include "fmgr.h" #include "nodes/params.h" #include "nodes/pathnodes.h" #include "parser/parse_node.h" #include "tcop/dest.h" #include "utils/queryenvironment.h" #include "utils/uuid.h" #define Natts_pg_ivm_immv 6 #define Anum_pg_ivm_immv_immvrelid 1 #define Anum_pg_ivm_immv_viewdef 2 #define Anum_pg_ivm_immv_ispopulated 3 #define Anum_pg_ivm_immv_lastivmupdate 4 #define Anum_pg_ivm_immv_querystring 5 #define Anum_pg_ivm_immv_immvuuid 6 typedef struct ImmvAddress { ObjectAddress address; pg_uuid_t immv_uuid; } ImmvAddress; /* pg_ivm.c */ extern void CreateChangePreventTrigger(Oid matviewOid); extern Oid PgIvmImmvRelationId(void); extern Oid PgIvmImmvPrimaryKeyIndexId(void); extern Oid PgIvmImmvUuidIndexId(void); extern bool isImmv(Oid immv_oid); extern List *PgIvmFuncName(char *name); extern void parse_immv_query(const char *relname, const char *sql, Query **query_ret, ParseState **pstate_ret); extern Oid GetImmvRelid(pg_uuid_t *immv_uuid); extern pg_uuid_t *GetImmvUuid(Oid immvrelid); /* createas.c */ extern ObjectAddress ExecCreateImmv(ParseState *pstate, CreateTableAsStmt *stmt, QueryCompletion *qc); extern void CreateIvmTriggersOnBaseTables(Query *qry, ImmvAddress immv_addr); extern void CreateIndexOnIMMV(Query *query, Relation matviewRel); extern Query *rewriteQueryForIMMV(Query *query, List *colNames); extern void makeIvmAggColumn(ParseState *pstate, Aggref *aggref, char *resname, AttrNumber *next_resno, List **aggs); /* matview.c */ extern Query *get_immv_query(Relation matviewRel); extern ObjectAddress ExecRefreshImmv(const RangeVar *relation, bool skipData, const char *queryString, QueryCompletion *qc); extern ObjectAddress RefreshImmvByOid(ImmvAddress immv_addr, bool is_create, bool skipData, const char *queryString, QueryCompletion *qc); extern bool ImmvIncrementalMaintenanceIsEnabled(void); extern Datum IVM_immediate_before(PG_FUNCTION_ARGS); extern Datum IVM_immediate_maintenance(PG_FUNCTION_ARGS); extern Query* rewrite_query_for_exists_subquery(Query *query); extern Datum ivm_visible_in_prestate(PG_FUNCTION_ARGS); extern void AtAbort_IVM(SubTransactionId subtxid); extern void AtPreCommit_IVM(void); extern char *getColumnNameStartWith(RangeTblEntry *rte, char *str, int *attnum); extern bool isIvmName(const char *s); /* ruleutils.c */ extern char *pg_ivm_get_viewdef(Relation immvrel, bool pretty); extern char *pg_ivm_get_viewdef_internal(Query *query, Relation immvrel, bool pretty); /* subselect.c */ extern void inline_cte(PlannerInfo *root, CommonTableExpr *cte); /* event_trigger.c */ extern Datum save_query_string(PG_FUNCTION_ARGS); extern Datum restore_query_string(PG_FUNCTION_ARGS); #if defined(PG_VERSION_NUM) && (PG_VERSION_NUM < 170000) extern void RestrictSearchPath(void); #endif #endif