On this page
44.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 FUNCTION tclsnitch();