PostgreSQL
 sql >> Datenbank >  >> RDS >> PostgreSQL

So erhalten Sie SQL-Text vom Postgres-Ereignisauslöser

Ab PostgreSQL 9.5, Funktion pg_event_trigger_ddl_commands() ist für ddl_command_end verfügbar Ereignisauslöser. Mit dem TAG filter, kann er zur Verarbeitung jeder ALTERed-Tabelle verwendet werden. object_identity (oder objid ) kann verwendet werden, um das ursprüngliche Problem zu lösen, zu wissen, welche Tabelle geändert wurde. Das Abrufen des vollständigen Befehls ist ebenfalls verfügbar, aber er ist vom internen Typ 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;

Ausgaben:NOTICE: caught ALTER TABLE event on public.t abgefangen