PostgreSQL Event Trigger
note
Neon Postgres currently does not support event triggers. For more information, see Event triggers in our Postgres compatibility guide.
Summary: in this tutorial, you will learn about PostgreSQL event triggers and how to use the CREATE EVENT TRIGGER
statement to define a new event trigger.
Introduction to the PostgreSQL event trigger
A regular trigger fires whenever an INSERT
, UPDATE
, DELETE
, or TRUNCATE
event occurs on an associated table.
To automatically respond to events related to data definition language (DDL
) statements, you can use an event trigger.
An event trigger is a trigger that fires whenever an associated event occurs in the database.
PostgreSQL supports the following events:
ddl_command_start
ddl_command_end
table_rewrite
sql_drop
The ddl_command_start
events before PostgreSQL executes the CREATE
, ALTER
, DROP
, GRANT
, REVOKE
, SECURITY
LABEL
, and COMMENT
statements. For complete commands that the event trigger supports, read more on the event trigger firing matrix.
Please note that the ddl_command_start
does not occur for shared objects like databases, tablespaces, and roles.
The ddl_command_end
occurs after the execution of the above DDL statements.
The sql_drop
event occurs whenever you drop a database object, just before the ddl_command_end
event.
The table_rewrite
event occurs before you rewrite a table using the ALTER TABLE
or ALTER TYPE
statement.
To create an event trigger, you follow these steps:
First, define a function that will execute when the event trigger fires:
The event trigger function returns EVENT_TRIGGER
instead of TRIGGER
. Additionally, it does not have any RETURN
statement like a regular trigger function.
Second, create an event trigger using the CREATE EVENT TRIGGER
statement:
PostgreSQL event trigger example
First, create a table called audits
to store audit logs for commands:
The audits
table will record the username, event, command, and timestamp when the command is executed.
Second, define an event trigger function that executes whenever a relevant event occurs:
The audit_command()
function inserts audit records into the audits
table.
Third, create an event trigger that associates the function with DDL commands:
Fourth, execute a CREATE TABLE
command:
Fifth, retrieve data from the audits
table:
Output:
Regular trigger vs. Event trigger
The following table compares regular triggers and event triggers:
Feature | Regular Trigger | Event Trigger |
---|---|---|
Trigger Level | Table-level trigger, associated with a specific table and fired on INSERT , UPDATE , DELETE , or TRUNCATE statement. | Database-level triggers fired in response to DDL statements such as CREATE , ALTER , DROP , etc. |
Execution Time | Can be fired BEFORE , AFTER , or INSTEAD OF DML operations | Fired at some events including ddl_command_start , ddl_command_end , table_rewrite , sql_drop |
Scope | Can be defined at the row or statement level | Executes at the database level |
Access to Data | Has access to the data being modified | Has access to metadata |
Use Cases | Logging changes to a specific table, updating related tables, and enforcing business rules. | Auditing DDL commands, and monitoring user activities. |
Summary
- An event trigger is a trigger that fires when an event related to the DDL statement occurs.
- Use the
CREATE EVENT TRIGGER
statement to define a new event trigger.