受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: 19 / devel
此文档适用于不受支持的 PostgreSQL 版本。
您可能需要查看当前版本的相同页面,或上面列出的其他受支持版本。

42.7. 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();