PostgreSQL Source Code git master
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
trigger.h
Go to the documentation of this file.
1/*-------------------------------------------------------------------------
2 *
3 * trigger.h
4 * Declarations for trigger handling.
5 *
6 * Portions Copyright (c) 1996-2025, PostgreSQL Global Development Group
7 * Portions Copyright (c) 1994, Regents of the University of California
8 *
9 * src/include/commands/trigger.h
10 *
11 *-------------------------------------------------------------------------
12 */
13#ifndef TRIGGER_H
14#define TRIGGER_H
15
16#include "access/tableam.h"
18#include "nodes/execnodes.h"
19#include "nodes/parsenodes.h"
20
21/*
22 * TriggerData is the node type that is passed as fmgr "context" info
23 * when a function is called by the trigger manager.
24 */
25
26#define CALLED_AS_TRIGGER(fcinfo) \
27 ((fcinfo)->context != NULL && IsA((fcinfo)->context, TriggerData))
28
30
31typedef struct TriggerData
32{
45
46/*
47 * The state for capturing old and new tuples into transition tables for a
48 * single ModifyTable node (or other operation source, e.g. copyfrom.c).
49 *
50 * This is per-caller to avoid conflicts in setting
51 * tcs_original_insert_tuple. Note, however, that the pointed-to
52 * private data may be shared across multiple callers.
53 */
54struct AfterTriggersTableData; /* private in trigger.c */
55
57{
58 /*
59 * Is there at least one trigger specifying each transition relation on
60 * the relation explicitly named in the DML statement or COPY command?
61 * Note: in current usage, these flags could be part of the private state,
62 * but it seems possibly useful to let callers see them.
63 */
68
69 /*
70 * For INSERT and COPY, it would be wasteful to convert tuples from child
71 * format to parent format after they have already been converted in the
72 * opposite direction during routing. In that case we bypass conversion
73 * and allow the inserting code (copyfrom.c and nodeModifyTable.c) to
74 * provide a slot containing the original tuple directly.
75 */
77
78 /*
79 * Private data including the tuplestore(s) into which to insert tuples.
80 */
83
84/*
85 * TriggerEvent bit flags
86 *
87 * Note that we assume different event types (INSERT/DELETE/UPDATE/TRUNCATE)
88 * can't be OR'd together in a single TriggerEvent. This is unlike the
89 * situation for pg_trigger rows, so pg_trigger.tgtype uses a different
90 * representation!
91 */
92#define TRIGGER_EVENT_INSERT 0x00000000
93#define TRIGGER_EVENT_DELETE 0x00000001
94#define TRIGGER_EVENT_UPDATE 0x00000002
95#define TRIGGER_EVENT_TRUNCATE 0x00000003
96#define TRIGGER_EVENT_OPMASK 0x00000003
97
98#define TRIGGER_EVENT_ROW 0x00000004
99
100#define TRIGGER_EVENT_BEFORE 0x00000008
101#define TRIGGER_EVENT_AFTER 0x00000000
102#define TRIGGER_EVENT_INSTEAD 0x00000010
103#define TRIGGER_EVENT_TIMINGMASK 0x00000018
104
105/* More TriggerEvent flags, used only within trigger.c */
106
107#define AFTER_TRIGGER_DEFERRABLE 0x00000020
108#define AFTER_TRIGGER_INITDEFERRED 0x00000040
109
110#define TRIGGER_FIRED_BY_INSERT(event) \
111 (((event) & TRIGGER_EVENT_OPMASK) == TRIGGER_EVENT_INSERT)
112
113#define TRIGGER_FIRED_BY_DELETE(event) \
114 (((event) & TRIGGER_EVENT_OPMASK) == TRIGGER_EVENT_DELETE)
115
116#define TRIGGER_FIRED_BY_UPDATE(event) \
117 (((event) & TRIGGER_EVENT_OPMASK) == TRIGGER_EVENT_UPDATE)
118
119#define TRIGGER_FIRED_BY_TRUNCATE(event) \
120 (((event) & TRIGGER_EVENT_OPMASK) == TRIGGER_EVENT_TRUNCATE)
121
122#define TRIGGER_FIRED_FOR_ROW(event) \
123 ((event) & TRIGGER_EVENT_ROW)
124
125#define TRIGGER_FIRED_FOR_STATEMENT(event) \
126 (!TRIGGER_FIRED_FOR_ROW(event))
127
128#define TRIGGER_FIRED_BEFORE(event) \
129 (((event) & TRIGGER_EVENT_TIMINGMASK) == TRIGGER_EVENT_BEFORE)
130
131#define TRIGGER_FIRED_AFTER(event) \
132 (((event) & TRIGGER_EVENT_TIMINGMASK) == TRIGGER_EVENT_AFTER)
133
134#define TRIGGER_FIRED_INSTEAD(event) \
135 (((event) & TRIGGER_EVENT_TIMINGMASK) == TRIGGER_EVENT_INSTEAD)
136
137/*
138 * Definitions for replication role based firing.
139 */
140#define SESSION_REPLICATION_ROLE_ORIGIN 0
141#define SESSION_REPLICATION_ROLE_REPLICA 1
142#define SESSION_REPLICATION_ROLE_LOCAL 2
144
145/*
146 * States at which a trigger can be fired. These are the
147 * possible values for pg_trigger.tgenabled.
148 */
149#define TRIGGER_FIRES_ON_ORIGIN 'O'
150#define TRIGGER_FIRES_ALWAYS 'A'
151#define TRIGGER_FIRES_ON_REPLICA 'R'
152#define TRIGGER_DISABLED 'D'
153
154extern ObjectAddress CreateTrigger(CreateTrigStmt *stmt, const char *queryString,
155 Oid relOid, Oid refRelOid, Oid constraintOid, Oid indexOid,
156 Oid funcoid, Oid parentTriggerOid, Node *whenClause,
157 bool isInternal, bool in_partition);
158extern ObjectAddress CreateTriggerFiringOn(CreateTrigStmt *stmt, const char *queryString,
159 Oid relOid, Oid refRelOid, Oid constraintOid,
160 Oid indexOid, Oid funcoid, Oid parentTriggerOid,
161 Node *whenClause, bool isInternal, bool in_partition,
162 char trigger_fires_when);
163
164extern void TriggerSetParentTrigger(Relation trigRel,
165 Oid childTrigId,
166 Oid parentTrigId,
167 Oid childTableId);
168extern void RemoveTriggerById(Oid trigOid);
169extern Oid get_trigger_oid(Oid relid, const char *trigname, bool missing_ok);
170
172
173extern void EnableDisableTrigger(Relation rel, const char *tgname, Oid tgparent,
174 char fires_when, bool skip_system, bool recurse,
175 LOCKMODE lockmode);
176
177extern void RelationBuildTriggers(Relation relation);
178
179extern TriggerDesc *CopyTriggerDesc(TriggerDesc *trigdesc);
180
181extern const char *FindTriggerIncompatibleWithInheritance(TriggerDesc *trigdesc);
182
185
186extern void FreeTriggerDesc(TriggerDesc *trigdesc);
187
188extern void ExecBSInsertTriggers(EState *estate,
189 ResultRelInfo *relinfo);
190extern void ExecASInsertTriggers(EState *estate,
191 ResultRelInfo *relinfo,
192 TransitionCaptureState *transition_capture);
193extern bool ExecBRInsertTriggers(EState *estate,
194 ResultRelInfo *relinfo,
195 TupleTableSlot *slot);
196extern void ExecARInsertTriggers(EState *estate,
197 ResultRelInfo *relinfo,
198 TupleTableSlot *slot,
199 List *recheckIndexes,
200 TransitionCaptureState *transition_capture);
201extern bool ExecIRInsertTriggers(EState *estate,
202 ResultRelInfo *relinfo,
203 TupleTableSlot *slot);
204extern void ExecBSDeleteTriggers(EState *estate,
205 ResultRelInfo *relinfo);
206extern void ExecASDeleteTriggers(EState *estate,
207 ResultRelInfo *relinfo,
208 TransitionCaptureState *transition_capture);
209extern bool ExecBRDeleteTriggers(EState *estate,
210 EPQState *epqstate,
211 ResultRelInfo *relinfo,
212 ItemPointer tupleid,
213 HeapTuple fdw_trigtuple,
214 TupleTableSlot **epqslot,
215 TM_Result *tmresult,
216 TM_FailureData *tmfd,
217 bool is_merge_delete);
218extern void ExecARDeleteTriggers(EState *estate,
219 ResultRelInfo *relinfo,
220 ItemPointer tupleid,
221 HeapTuple fdw_trigtuple,
222 TransitionCaptureState *transition_capture,
223 bool is_crosspart_update);
224extern bool ExecIRDeleteTriggers(EState *estate,
225 ResultRelInfo *relinfo,
226 HeapTuple trigtuple);
227extern void ExecBSUpdateTriggers(EState *estate,
228 ResultRelInfo *relinfo);
229extern void ExecASUpdateTriggers(EState *estate,
230 ResultRelInfo *relinfo,
231 TransitionCaptureState *transition_capture);
232extern bool ExecBRUpdateTriggers(EState *estate,
233 EPQState *epqstate,
234 ResultRelInfo *relinfo,
235 ItemPointer tupleid,
236 HeapTuple fdw_trigtuple,
237 TupleTableSlot *newslot,
238 TM_Result *tmresult,
239 TM_FailureData *tmfd,
240 bool is_merge_update);
241extern void ExecARUpdateTriggers(EState *estate,
242 ResultRelInfo *relinfo,
243 ResultRelInfo *src_partinfo,
244 ResultRelInfo *dst_partinfo,
245 ItemPointer tupleid,
246 HeapTuple fdw_trigtuple,
247 TupleTableSlot *newslot,
248 List *recheckIndexes,
249 TransitionCaptureState *transition_capture,
250 bool is_crosspart_update);
251extern bool ExecIRUpdateTriggers(EState *estate,
252 ResultRelInfo *relinfo,
253 HeapTuple trigtuple,
254 TupleTableSlot *newslot);
255extern void ExecBSTruncateTriggers(EState *estate,
256 ResultRelInfo *relinfo);
257extern void ExecASTruncateTriggers(EState *estate,
258 ResultRelInfo *relinfo);
259
260extern void AfterTriggerBeginXact(void);
261extern void AfterTriggerBeginQuery(void);
262extern void AfterTriggerEndQuery(EState *estate);
263extern void AfterTriggerFireDeferred(void);
264extern void AfterTriggerEndXact(bool isCommit);
265extern void AfterTriggerBeginSubXact(void);
266extern void AfterTriggerEndSubXact(bool isCommit);
269
270
271/*
272 * in utils/adt/ri_triggers.c
273 */
274extern bool RI_FKey_pk_upd_check_required(Trigger *trigger, Relation pk_rel,
275 TupleTableSlot *oldslot, TupleTableSlot *newslot);
276extern bool RI_FKey_fk_upd_check_required(Trigger *trigger, Relation fk_rel,
277 TupleTableSlot *oldslot, TupleTableSlot *newslot);
278extern bool RI_Initial_Check(Trigger *trigger,
279 Relation fk_rel, Relation pk_rel);
280extern void RI_PartitionRemove_Check(Trigger *trigger, Relation fk_rel,
281 Relation pk_rel);
282
283/* result values for RI_FKey_trigger_type: */
284#define RI_TRIGGER_PK 1 /* is a trigger on the PK relation */
285#define RI_TRIGGER_FK 2 /* is a trigger on the FK relation */
286#define RI_TRIGGER_NONE 0 /* is not an RI trigger function */
287
288extern int RI_FKey_trigger_type(Oid tgfoid);
289
290#endif /* TRIGGER_H */
#define PGDLLIMPORT
Definition: c.h:1319
uint32_t uint32
Definition: c.h:538
#define stmt
Definition: indent_codes.h:59
int LOCKMODE
Definition: lockdefs.h:26
CmdType
Definition: nodes.h:273
NodeTag
Definition: nodes.h:27
unsigned int Oid
Definition: postgres_ext.h:32
Definition: pg_list.h:54
Definition: nodes.h:135
struct AfterTriggersTableData * tcs_private
Definition: trigger.h:81
TupleTableSlot * tcs_original_insert_tuple
Definition: trigger.h:76
Tuplestorestate * tg_oldtable
Definition: trigger.h:41
NodeTag type
Definition: trigger.h:33
Relation tg_relation
Definition: trigger.h:35
const Bitmapset * tg_updatedcols
Definition: trigger.h:43
Tuplestorestate * tg_newtable
Definition: trigger.h:42
TriggerEvent tg_event
Definition: trigger.h:34
TupleTableSlot * tg_trigslot
Definition: trigger.h:39
HeapTuple tg_newtuple
Definition: trigger.h:37
TupleTableSlot * tg_newslot
Definition: trigger.h:40
Trigger * tg_trigger
Definition: trigger.h:38
HeapTuple tg_trigtuple
Definition: trigger.h:36
TM_Result
Definition: tableam.h:73
uint32 TriggerEvent
Definition: trigger.h:29
bool ExecBRUpdateTriggers(EState *estate, EPQState *epqstate, ResultRelInfo *relinfo, ItemPointer tupleid, HeapTuple fdw_trigtuple, TupleTableSlot *newslot, TM_Result *tmresult, TM_FailureData *tmfd, bool is_merge_update)
Definition: trigger.c:2971
TransitionCaptureState * MakeTransitionCaptureState(TriggerDesc *trigdesc, Oid relid, CmdType cmdType)
Definition: trigger.c:4968
void AfterTriggerBeginXact(void)
Definition: trigger.c:5072
void ExecARDeleteTriggers(EState *estate, ResultRelInfo *relinfo, ItemPointer tupleid, HeapTuple fdw_trigtuple, TransitionCaptureState *transition_capture, bool is_crosspart_update)
Definition: trigger.c:2801
void ExecBSInsertTriggers(EState *estate, ResultRelInfo *relinfo)
Definition: trigger.c:2401
bool ExecBRInsertTriggers(EState *estate, ResultRelInfo *relinfo, TupleTableSlot *slot)
Definition: trigger.c:2465
void AfterTriggerEndSubXact(bool isCommit)
Definition: trigger.c:5435
bool RI_FKey_pk_upd_check_required(Trigger *trigger, Relation pk_rel, TupleTableSlot *oldslot, TupleTableSlot *newslot)
Definition: ri_triggers.c:1384
void ExecBSTruncateTriggers(EState *estate, ResultRelInfo *relinfo)
Definition: trigger.c:3280
PGDLLIMPORT int SessionReplicationRole
Definition: trigger.c:63
void FreeTriggerDesc(TriggerDesc *trigdesc)
Definition: trigger.c:2145
bool ExecIRDeleteTriggers(EState *estate, ResultRelInfo *relinfo, HeapTuple trigtuple)
Definition: trigger.c:2848
void ExecBSDeleteTriggers(EState *estate, ResultRelInfo *relinfo)
Definition: trigger.c:2630
void EnableDisableTrigger(Relation rel, const char *tgname, Oid tgparent, char fires_when, bool skip_system, bool recurse, LOCKMODE lockmode)
Definition: trigger.c:1726
const char * FindTriggerIncompatibleWithInheritance(TriggerDesc *trigdesc)
Definition: trigger.c:2277
bool ExecIRInsertTriggers(EState *estate, ResultRelInfo *relinfo, TupleTableSlot *slot)
Definition: trigger.c:2569
void ExecASTruncateTriggers(EState *estate, ResultRelInfo *relinfo)
Definition: trigger.c:3327
void ExecARUpdateTriggers(EState *estate, ResultRelInfo *relinfo, ResultRelInfo *src_partinfo, ResultRelInfo *dst_partinfo, ItemPointer tupleid, HeapTuple fdw_trigtuple, TupleTableSlot *newslot, List *recheckIndexes, TransitionCaptureState *transition_capture, bool is_crosspart_update)
Definition: trigger.c:3144
void AfterTriggerSetState(ConstraintsSetStmt *stmt)
Definition: trigger.c:5745
bool ExecBRDeleteTriggers(EState *estate, EPQState *epqstate, ResultRelInfo *relinfo, ItemPointer tupleid, HeapTuple fdw_trigtuple, TupleTableSlot **epqslot, TM_Result *tmresult, TM_FailureData *tmfd, bool is_merge_delete)
Definition: trigger.c:2701
Oid get_trigger_oid(Oid relid, const char *trigname, bool missing_ok)
Definition: trigger.c:1370
ObjectAddress CreateTrigger(CreateTrigStmt *stmt, const char *queryString, Oid relOid, Oid refRelOid, Oid constraintOid, Oid indexOid, Oid funcoid, Oid parentTriggerOid, Node *whenClause, bool isInternal, bool in_partition)
Definition: trigger.c:160
struct TriggerData TriggerData
void ExecASUpdateTriggers(EState *estate, ResultRelInfo *relinfo, TransitionCaptureState *transition_capture)
Definition: trigger.c:2953
void ExecASDeleteTriggers(EState *estate, ResultRelInfo *relinfo, TransitionCaptureState *transition_capture)
Definition: trigger.c:2681
ObjectAddress renametrig(RenameStmt *stmt)
Definition: trigger.c:1467
void AfterTriggerFireDeferred(void)
Definition: trigger.c:5283
void ExecARInsertTriggers(EState *estate, ResultRelInfo *relinfo, TupleTableSlot *slot, List *recheckIndexes, TransitionCaptureState *transition_capture)
Definition: trigger.c:2543
void TriggerSetParentTrigger(Relation trigRel, Oid childTrigId, Oid parentTrigId, Oid childTableId)
Definition: trigger.c:1220
struct TransitionCaptureState TransitionCaptureState
void ExecASInsertTriggers(EState *estate, ResultRelInfo *relinfo, TransitionCaptureState *transition_capture)
Definition: trigger.c:2452
ObjectAddress CreateTriggerFiringOn(CreateTrigStmt *stmt, const char *queryString, Oid relOid, Oid refRelOid, Oid constraintOid, Oid indexOid, Oid funcoid, Oid parentTriggerOid, Node *whenClause, bool isInternal, bool in_partition, char trigger_fires_when)
Definition: trigger.c:177
TriggerDesc * CopyTriggerDesc(TriggerDesc *trigdesc)
Definition: trigger.c:2090
bool ExecIRUpdateTriggers(EState *estate, ResultRelInfo *relinfo, HeapTuple trigtuple, TupleTableSlot *newslot)
Definition: trigger.c:3214
void AfterTriggerEndXact(bool isCommit)
Definition: trigger.c:5339
bool AfterTriggerPendingOnRel(Oid relid)
Definition: trigger.c:6060
bool RI_Initial_Check(Trigger *trigger, Relation fk_rel, Relation pk_rel)
Definition: ri_triggers.c:1517
void RelationBuildTriggers(Relation relation)
Definition: trigger.c:1861
void AfterTriggerBeginSubXact(void)
Definition: trigger.c:5387
void RI_PartitionRemove_Check(Trigger *trigger, Relation fk_rel, Relation pk_rel)
Definition: ri_triggers.c:1811
bool RI_FKey_fk_upd_check_required(Trigger *trigger, Relation fk_rel, TupleTableSlot *oldslot, TupleTableSlot *newslot)
Definition: ri_triggers.c:1416
int RI_FKey_trigger_type(Oid tgfoid)
Definition: ri_triggers.c:3208
void AfterTriggerEndQuery(EState *estate)
Definition: trigger.c:5124
void RemoveTriggerById(Oid trigOid)
Definition: trigger.c:1291
void ExecBSUpdateTriggers(EState *estate, ResultRelInfo *relinfo)
Definition: trigger.c:2895
void AfterTriggerBeginQuery(void)
Definition: trigger.c:5104