受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

43.7. PL/Perl 事件触发器 #

PL/Perl 可用于编写事件触发器函数。在事件触发器函数中,哈希引用 $_TD 包含有关当前触发器事件的信息。 $_TD 是一个全局变量,对触发器的每一次调用都会得到 一个单独的局部值。$_TD 哈希引用包含以下字段:

$_TD->{event} #

该触发器所针对的事件名称。

$_TD->{tag} #

该触发器所针对的命令标签。

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

下面是一个事件触发器函数示例,用于说明上述部分内容:

CREATE OR REPLACE FUNCTION perlsnitch() RETURNS event_trigger AS $$
  elog(NOTICE, "perlsnitch: " . $_TD->{event} . " " . $_TD->{tag} . " ");
$$ LANGUAGE plperl;

CREATE EVENT TRIGGER perl_a_snitch
    ON ddl_command_start
    EXECUTE FUNCTION perlsnitch();

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。