Quick onboard
Deployment
Data Modeling
Connecting
Migration
Query
Operations and Maintenance
Common Maintenance
Partition
Backup and Restore
Expansion
Mirroring
Resource Management
Security
Monitoring
Performance Tuning
Troubleshooting
Reference Guide
Tool guide
Data type
Storage Engine
Executor
Stream
DR (Disaster Recovery)
Configuration
Index
Extension
SQL Reference
Defines a new trigger. User-defined triggers are not supported in Database.
CREATE TRIGGER <name> {BEFORE | AFTER} {<event> [OR ...]}
ON <table> [ FOR [EACH] {ROW | STATEMENT} ]
EXECUTE PROCEDURE <funcname> ( <arguments> )
CREATE TRIGGER
creates a new trigger. The trigger will be associated with the specified table and will run the specified function when certain events occur. If multiple triggers of the same kind are defined for the same event, they will be fired in alphabetical order by name.
Important Due to the distributed nature of a Database system, the use of triggers on data is very limited in Database. The function used in the trigger must be IMMUTABLE, meaning it cannot use information not directly present in its argument list. The function specified in the trigger also cannot run any SQL or modify distributed database objects in any way. Given that triggers are most often used to alter tables (for example, update these other rows when this row is updated), these limitations offer very little practical use of triggers in Database. For that reason, does not support the use of user-defined triggers in Database. Triggers cannot be used on append-optimized tables. Event Triggers, which capture only DDL events, are supported in Database. See the PostgreSQL documentation for Event Triggers for additional information.
SELECT does not modify any rows so you can not create SELECT triggers. Rules and views are more appropriate in such cases.
INSERT
, UPDATE
, or DELETE
). Multiple events can be specified using OR.To create a trigger on a table, the user must have the TRIGGER privilege on the table.
Declare the trigger function and then a trigger:
CREATE FUNCTION sendmail() RETURNS trigger AS
'$GPHOME/lib/emailtrig.so' LANGUAGE C IMMUTABLE;
CREATE TRIGGER t_sendmail AFTER INSERT OR UPDATE OR DELETE
ON mytable FOR EACH STATEMENT EXECUTE PROCEDURE sendmail();
The CREATE TRIGGER
statement in Database implements a subset of the SQL standard. The following functionality is currently missing:
Database has strict limitations on the function that is called by a trigger, which makes the use of triggers very limited in Database. For this reason, triggers are not officially supported in Database.
SQL allows triggers to fire on updates to specific columns (e.g., AFTER UPDATE OF col1, col2
).
SQL allows you to define aliases for the 'old' and 'new' rows or tables for use in the definition of the triggered action (e.g., CREATE TRIGGER ... ON tablename REFERENCING OLD ROW AS somename NEW ROW AS othername ...
). Since Database allows trigger procedures to be written in any number of user-defined languages, access to the data is handled in a language-specific way.
Database only allows the execution of a user-defined function for the triggered action. The standard allows the execution of a number of other SQL commands, such as CREATE TABLE
as the triggered action. This limitation is not hard to work around by creating a user-defined function that runs the desired commands.
SQL specifies that multiple triggers should be fired in time-of-creation order. Database uses name order, which was judged to be more convenient.
SQL specifies that BEFORE DELETE
triggers on cascaded deletes fire after the cascaded DELETE
completes. The Database behavior is for BEFORE DELETE
to always fire before the delete action, even a cascading one. This is considered more consistent.
The ability to specify multiple actions for a single trigger using OR
is a Database extension of the SQL standard.