gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-29 11:10:25 25 4
gpt4 key购买 nike

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

pg 变量不包括这个,GET STACKED DIAGNOSTICS 公开的变量也不包括。

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

例如,如果

ALTER TABLE base1 ADD COLUMN col1 int;

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

最佳答案

从 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 事件

关于postgresql - 如何从 Postgres 事件触发器中获取 SQL 文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23488228/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com