Postgresql 中文操作指南

45.7. PL/Perl Event Triggers #

可以使用 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();