PostgreSQL
 sql >> Base de Dados >  >> RDS >> PostgreSQL

Como obter o texto SQL do gatilho de evento do Postgres


A partir do PostgreSQL 9.5, função pg_event_trigger_ddl_commands() está disponível para ddl_command_end acionadores de eventos. Usando a TAG filtro, ele pode ser usado para processar qualquer tabela ALTERed. object_identity (ou objid ) pode ser usado para resolver o problema original de saber qual tabela foi alterada. Quanto a obter o comando completo, ele também está disponível, mas é do tipo interno 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;

outputs:NOTICE: caught ALTER TABLE event on public.t