Започвайки от 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