cc *_*ung 18 postgresql triggers plpgsql
在标记ALTER TABLE的pgsql事件触发器中,我希望知道正在更改哪个表.
pg变量不包括这一点,GET STACKED DIAGNOSTICS也没有暴露变量.
有了可用的变量,触发器函数本身是否有任何方法可以查看负责启动该函数的SQL命令的文本.
例如,如果
ALTER TABLE base1 ADD COLUMN col1 int;
Run Code Online (Sandbox Code Playgroud)
负责调用事件触发器,是否有任何方式在事件触发器中查看ALTER TABLE base1 ADD COLUMN col1 int文本本身?
Ond*_*uda 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;
Run Code Online (Sandbox Code Playgroud)
输出:
NOTICE: caught ALTER TABLE event on public.t
| 归档时间: |
|
| 查看次数: |
4151 次 |
| 最近记录: |