Skip to content

CREATE EVENT TRIGGER

CREATE EVENT TRIGGER — 定义新的事件触发器

语法

CREATE EVENT TRIGGER name
    ON event
    [ WHEN filter_variable IN (filter_value [, ... ]) [ AND ... ] ]
    EXECUTE { FUNCTION | PROCEDURE } function_name()

描述

CREATE EVENT TRIGGER创建一个新的事件触发器。每当指定的事件发生并且触发器关联的WHEN条件(如果存在)得到满足时,触发器函数将被执行。有关事件触发器的总体介绍,请参阅第 40 章。创建事件触发器的用户将成为其所有者。

参数

name

赋予新触发器的名称。此名称在数据库中必须是唯一的。

event

触发对给定函数的调用的事件的名称。有关事件名称的更多信息,请参阅第 40.1 节

filter_variable

用于过滤事件的变量名称。这使得可以将触发器的触发限制为其支持的情况的子集。目前唯一支持的 filter_variableTAG

filter_value

与关联的 filter_variable 的值列表,触发器应为此值触发。对于 TAG,这意味着命令标记列表(例如,'DROP FUNCTION')。

function_name

用户提供的函数,声明为不接受参数并返回 event_trigger 类型。

CREATE EVENT TRIGGER 的语法中,关键字 FUNCTIONPROCEDURE 是等效的,但引用的函数在任何情况下都必须是函数,而不是过程。此处使用关键字 PROCEDURE 是历史遗留问题,已被弃用。

注释

只有超级用户才能创建事件触发器。

事件触发器在单用户模式下禁用(请参阅postgres)。如果错误的事件触发器使数据库禁用,以至于你甚至无法删除触发器,请在单用户模式下重新启动,你将能够执行此操作。

示例

禁止执行任何DDL命令

CREATE OR REPLACE FUNCTION abort_any_command()
  RETURNS event_trigger
 LANGUAGE plpgsql
  AS $$
BEGIN
  RAISE EXCEPTION 'command % is disabled', tg_tag;
END;
$$;

CREATE EVENT TRIGGER abort_ddl ON ddl_command_start
   EXECUTE FUNCTION abort_any_command();

兼容性

SQL 标准中没有CREATE EVENT TRIGGER语句。

另请参阅

ALTER EVENT TRIGGERDROP EVENT TRIGGERCREATE FUNCTION