如何从Postgres事件触发器获取SQL文本

时间:2014-05-06 07:15:07

标签: postgresql triggers plpgsql

在标签ALTER TABLE上的pgsql事件触发器中,我想知道哪个表正在被更改。

pg变量不包括这个,GET STACKED DIAGNOSTICS也没有暴露变量。

如果变量可用,触发器函数本身是否有任何方法可以查看负责启动该函数的SQL命令的文本。

例如,如果

ALTER TABLE base1 ADD COLUMN col1 int;

负责调用事件触发器,在事件触发器中是否有任何方式可以看到ALTER TABLE base1 ADD COLUMN col1 int文本本身?

1 个答案:

答案 0 :(得分:19)

从PostgreSQL 9.5开始,函数pg_event_trigger_ddl_commands()可用于ddl_command_end个事件触发器。使用TAG过滤器,它可用于处理任何ALTERed表。 object_identity(或objid)可用于解决知道哪个表已被更改的原始问题。至于获取完整命令,它也可用,但它是内部类型pg_ddl_command

CREATE TABLE t (n INT);

CREATE FUNCTION notice_event() RETURNS event_trigger AS $$
DECLARE r RECORD;
BEGIN
    FOR r IN SELECT * FROM pg_event_trigger_ddl_commands() LOOP
        RAISE NOTICE 'caught % event on %', r.command_tag, r.object_identity;
    END LOOP;
END;
$$
LANGUAGE plpgsql;

CREATE EVENT TRIGGER tr_notice_alter_table
  ON ddl_command_end WHEN TAG IN ('ALTER TABLE')
  EXECUTE PROCEDURE notice_event();

ALTER TABLE t ADD c CHAR;

输出: NOTICE: caught ALTER TABLE event on public.t