在标签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事件