加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-13 16:27:40 所属栏目:百科 来源:网络整理
导读:在标签ALTER TABLE上的pgsql事件触发器中,我想知道哪个表被更改. pg变量不包括这一点,也不是GET堆栈诊断暴露的变量. 使用变量可用,触发器函数本身是否有任何方式查看负责启动函数的SQL命令的文本. 例如,如果 ALTER TABLE base1 ADD COLUMN col1 int; 负责调
在标签ALTER TABLE上的pgsql事件触发器中,我想知道哪个表被更改.

pg变量不包括这一点,也不是GET堆栈诊断暴露的变量.

使用变量可用,触发器函数本身是否有任何方式查看负责启动函数的SQL命令的文本.

例如,如果

ALTER TABLE base1 ADD COLUMN col1 int;

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

从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;

输出:注意:在public.t上捕获了ALTER TABLE事件

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读