2024年9月26日:PostgreSQL 17 发布!
支持的版本:当前 (17) / 16 / 15 / 14 / 13 / 12
开发版本:开发版
不支持的版本:11 / 10 / 9.6 / 9.5 / 9.4 / 9.3

38.3. 使用 C 编写事件触发器函数 #

本节描述了事件触发器函数接口的底层细节。只有在使用 C 编写事件触发器函数时才需要这些信息。如果您使用的是更高级别的语言,那么这些细节将由语言为您处理。在大多数情况下,您应该考虑在使用 C 编写事件触发器之前使用过程语言。每种过程语言的文档都解释了如何在该语言中编写事件触发器。

事件触发器函数必须使用“版本 1”函数管理器接口。

当事件触发器管理器调用函数时,不会传递任何正常的参数,但会传递一个指向 EventTriggerData 结构的“上下文”指针。C 函数可以通过执行宏来检查它们是否是由事件触发器管理器调用的

CALLED_AS_EVENT_TRIGGER(fcinfo)

它展开为

((fcinfo)->context != NULL && IsA((fcinfo)->context, EventTriggerData))

如果此返回值为真,则可以安全地将 fcinfo->context 转换为 EventTriggerData * 类型并使用指向的 EventTriggerData 结构。函数不得更改 EventTriggerData 结构或其指向的任何数据。

struct EventTriggerDatacommands/event_trigger.h 中定义

typedef struct EventTriggerData
{
    NodeTag     type;
    const char *event;      /* event name */
    Node       *parsetree;  /* parse tree */
    CommandTag  tag;        /* command tag */
} EventTriggerData;

其中成员定义如下

类型

始终为 T_EventTriggerData

事件

描述调用函数的事件,可以是 "login""ddl_command_start""ddl_command_end""sql_drop""table_rewrite" 之一。有关这些事件的含义,请参见第 38.1 节

解析树

指向命令解析树的指针。有关详细信息,请检查 PostgreSQL 源代码。解析树结构可能会在未经通知的情况下发生更改。

标签

与运行事件触发器的事件关联的命令标签,例如 "CREATE FUNCTION"

事件触发器函数必须返回一个 NULL 指针(不是 SQL 空值,即不要将 isNull 设置为 true)。

提交更正

如果您在文档中看到任何不正确的内容、与您对特定功能的体验不符的内容或需要进一步澄清的内容,请使用此表单报告文档问题。