Postgresql 中文操作指南

44.7. Event Trigger Functions in PL/Tcl #

事件触发器函数可以使用 PL/Tcl 编写。PostgreSQL 要求将被用作事件触发器的函数声明为无参数且返回类型 event_trigger 的函数。

触发器管理器的信息通过以下变量传递到函数主体:

  • $TG_event

    • 触发器被触发的事件的名称。

  • $TG_tag

    • 触发器被触发的命令标记。

将忽略触发器函数的返回值。

以下是一个简单的示例事件触发器函数,它将在每次执行支持的命令时引发 NOTICE 消息:

CREATE OR REPLACE FUNCTION tclsnitch() RETURNS event_trigger AS $$
  elog NOTICE "tclsnitch: $TG_event $TG_tag"
$$ LANGUAGE pltcl;

CREATE EVENT TRIGGER tcl_a_snitch ON ddl_command_start EXECUTE FUNCTION tclsnitch();