pg_trigger.h 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. /*-------------------------------------------------------------------------
  2. *
  3. * pg_trigger.h
  4. * definition of the "trigger" system catalog (pg_trigger)
  5. *
  6. *
  7. * Portions Copyright (c) 1996-2022, PostgreSQL Global Development Group
  8. * Portions Copyright (c) 1994, Regents of the University of California
  9. *
  10. * src/include/catalog/pg_trigger.h
  11. *
  12. * NOTES
  13. * The Catalog.pm module reads this file and derives schema
  14. * information.
  15. *
  16. *-------------------------------------------------------------------------
  17. */
  18. #ifndef PG_TRIGGER_H
  19. #define PG_TRIGGER_H
  20. #include "catalog/genbki.h"
  21. #include "catalog/pg_trigger_d.h"
  22. /* ----------------
  23. * pg_trigger definition. cpp turns this into
  24. * typedef struct FormData_pg_trigger
  25. *
  26. * Note: when tgconstraint is nonzero, tgconstrrelid, tgconstrindid,
  27. * tgdeferrable, and tginitdeferred are largely redundant with the referenced
  28. * pg_constraint entry. However, it is possible for a non-deferrable trigger
  29. * to be associated with a deferrable constraint.
  30. * ----------------
  31. */
  32. CATALOG(pg_trigger,2620,TriggerRelationId)
  33. {
  34. Oid oid; /* oid */
  35. Oid tgrelid BKI_LOOKUP(pg_class); /* relation trigger is
  36. * attached to */
  37. Oid tgparentid BKI_LOOKUP_OPT(pg_trigger); /* OID of parent
  38. * trigger, if any */
  39. NameData tgname; /* trigger's name */
  40. Oid tgfoid BKI_LOOKUP(pg_proc); /* OID of function to be called */
  41. int16 tgtype; /* BEFORE/AFTER/INSTEAD, UPDATE/DELETE/INSERT,
  42. * ROW/STATEMENT; see below */
  43. char tgenabled; /* trigger's firing configuration WRT
  44. * session_replication_role */
  45. bool tgisinternal; /* trigger is system-generated */
  46. Oid tgconstrrelid BKI_LOOKUP_OPT(pg_class); /* constraint's FROM
  47. * table, if any */
  48. Oid tgconstrindid BKI_LOOKUP_OPT(pg_class); /* constraint's
  49. * supporting index, if
  50. * any */
  51. Oid tgconstraint BKI_LOOKUP_OPT(pg_constraint); /* associated
  52. * pg_constraint entry,
  53. * if any */
  54. bool tgdeferrable; /* constraint trigger is deferrable */
  55. bool tginitdeferred; /* constraint trigger is deferred initially */
  56. int16 tgnargs; /* # of extra arguments in tgargs */
  57. /*
  58. * Variable-length fields start here, but we allow direct access to
  59. * tgattr. Note: tgattr and tgargs must not be null.
  60. */
  61. int2vector tgattr BKI_FORCE_NOT_NULL; /* column numbers, if trigger is
  62. * on columns */
  63. #ifdef CATALOG_VARLEN
  64. bytea tgargs BKI_FORCE_NOT_NULL; /* first\000second\000tgnargs\000 */
  65. pg_node_tree tgqual; /* WHEN expression, or NULL if none */
  66. NameData tgoldtable; /* old transition table, or NULL if none */
  67. NameData tgnewtable; /* new transition table, or NULL if none */
  68. #endif
  69. } FormData_pg_trigger;
  70. /* ----------------
  71. * Form_pg_trigger corresponds to a pointer to a tuple with
  72. * the format of pg_trigger relation.
  73. * ----------------
  74. */
  75. typedef FormData_pg_trigger *Form_pg_trigger;
  76. DECLARE_TOAST(pg_trigger, 2336, 2337);
  77. DECLARE_INDEX(pg_trigger_tgconstraint_index, 2699, TriggerConstraintIndexId, on pg_trigger using btree(tgconstraint oid_ops));
  78. DECLARE_UNIQUE_INDEX(pg_trigger_tgrelid_tgname_index, 2701, TriggerRelidNameIndexId, on pg_trigger using btree(tgrelid oid_ops, tgname name_ops));
  79. DECLARE_UNIQUE_INDEX_PKEY(pg_trigger_oid_index, 2702, TriggerOidIndexId, on pg_trigger using btree(oid oid_ops));
  80. DECLARE_ARRAY_FOREIGN_KEY((tgrelid, tgattr), pg_attribute, (attrelid, attnum));
  81. #ifdef EXPOSE_TO_CLIENT_CODE
  82. /* Bits within tgtype */
  83. #define TRIGGER_TYPE_ROW (1 << 0)
  84. #define TRIGGER_TYPE_BEFORE (1 << 1)
  85. #define TRIGGER_TYPE_INSERT (1 << 2)
  86. #define TRIGGER_TYPE_DELETE (1 << 3)
  87. #define TRIGGER_TYPE_UPDATE (1 << 4)
  88. #define TRIGGER_TYPE_TRUNCATE (1 << 5)
  89. #define TRIGGER_TYPE_INSTEAD (1 << 6)
  90. #define TRIGGER_TYPE_LEVEL_MASK (TRIGGER_TYPE_ROW)
  91. #define TRIGGER_TYPE_STATEMENT 0
  92. /* Note bits within TRIGGER_TYPE_TIMING_MASK aren't adjacent */
  93. #define TRIGGER_TYPE_TIMING_MASK \
  94. (TRIGGER_TYPE_BEFORE | TRIGGER_TYPE_INSTEAD)
  95. #define TRIGGER_TYPE_AFTER 0
  96. #define TRIGGER_TYPE_EVENT_MASK \
  97. (TRIGGER_TYPE_INSERT | TRIGGER_TYPE_DELETE | TRIGGER_TYPE_UPDATE | TRIGGER_TYPE_TRUNCATE)
  98. /* Macros for manipulating tgtype */
  99. #define TRIGGER_CLEAR_TYPE(type) ((type) = 0)
  100. #define TRIGGER_SETT_ROW(type) ((type) |= TRIGGER_TYPE_ROW)
  101. #define TRIGGER_SETT_STATEMENT(type) ((type) |= TRIGGER_TYPE_STATEMENT)
  102. #define TRIGGER_SETT_BEFORE(type) ((type) |= TRIGGER_TYPE_BEFORE)
  103. #define TRIGGER_SETT_AFTER(type) ((type) |= TRIGGER_TYPE_AFTER)
  104. #define TRIGGER_SETT_INSTEAD(type) ((type) |= TRIGGER_TYPE_INSTEAD)
  105. #define TRIGGER_SETT_INSERT(type) ((type) |= TRIGGER_TYPE_INSERT)
  106. #define TRIGGER_SETT_DELETE(type) ((type) |= TRIGGER_TYPE_DELETE)
  107. #define TRIGGER_SETT_UPDATE(type) ((type) |= TRIGGER_TYPE_UPDATE)
  108. #define TRIGGER_SETT_TRUNCATE(type) ((type) |= TRIGGER_TYPE_TRUNCATE)
  109. #define TRIGGER_FOR_ROW(type) ((type) & TRIGGER_TYPE_ROW)
  110. #define TRIGGER_FOR_BEFORE(type) (((type) & TRIGGER_TYPE_TIMING_MASK) == TRIGGER_TYPE_BEFORE)
  111. #define TRIGGER_FOR_AFTER(type) (((type) & TRIGGER_TYPE_TIMING_MASK) == TRIGGER_TYPE_AFTER)
  112. #define TRIGGER_FOR_INSTEAD(type) (((type) & TRIGGER_TYPE_TIMING_MASK) == TRIGGER_TYPE_INSTEAD)
  113. #define TRIGGER_FOR_INSERT(type) ((type) & TRIGGER_TYPE_INSERT)
  114. #define TRIGGER_FOR_DELETE(type) ((type) & TRIGGER_TYPE_DELETE)
  115. #define TRIGGER_FOR_UPDATE(type) ((type) & TRIGGER_TYPE_UPDATE)
  116. #define TRIGGER_FOR_TRUNCATE(type) ((type) & TRIGGER_TYPE_TRUNCATE)
  117. /*
  118. * Efficient macro for checking if tgtype matches a particular level
  119. * (TRIGGER_TYPE_ROW or TRIGGER_TYPE_STATEMENT), timing (TRIGGER_TYPE_BEFORE,
  120. * TRIGGER_TYPE_AFTER or TRIGGER_TYPE_INSTEAD), and event (TRIGGER_TYPE_INSERT,
  121. * TRIGGER_TYPE_DELETE, TRIGGER_TYPE_UPDATE, or TRIGGER_TYPE_TRUNCATE). Note
  122. * that a tgtype can match more than one event, but only one level or timing.
  123. */
  124. #define TRIGGER_TYPE_MATCHES(type, level, timing, event) \
  125. (((type) & (TRIGGER_TYPE_LEVEL_MASK | TRIGGER_TYPE_TIMING_MASK | (event))) == ((level) | (timing) | (event)))
  126. /*
  127. * Macro to determine whether tgnewtable or tgoldtable has been specified for
  128. * a trigger.
  129. */
  130. #define TRIGGER_USES_TRANSITION_TABLE(namepointer) \
  131. ((namepointer) != (char *) NULL)
  132. #endif /* EXPOSE_TO_CLIENT_CODE */
  133. #endif /* PG_TRIGGER_H */