43.7. PL/Tcl 中的事件触发过程

事件触发过程可以用 PL/Tcl 编写。 PostgreSQL 要求将被称为事件触发器的过程必须声明为不带参数且返回类型为event_trigger的函数。

来自触发器 Management 器的信息将通过以下变量传递到过程主体:

  • $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 PROCEDURE tclsnitch();