Package org.h2.api
Interface Trigger
- All Known Implementing Classes:
FullText.FullTextTrigger
,FullTextLucene.FullTextTrigger
,TriggerAdapter
public interface Trigger
A class that implements this interface can be used as a trigger.
-
Field Summary
Modifier and TypeFieldDescriptionstatic final int
The trigger is called for DELETE statements.static final int
The trigger is called for INSERT statements.static final int
The trigger is called for SELECT statements.static final int
The trigger is called for UPDATE statements. -
Method Summary
Modifier and TypeMethodDescriptiondefault void
close()
This method is called when the database is closed.void
fire
(Connection conn, Object[] oldRow, Object[] newRow) This method is called for each triggered action.default void
init
(Connection conn, String schemaName, String triggerName, String tableName, boolean before, int type) This method is called by the database engine once when initializing the trigger.default void
remove()
This method is called when the trigger is dropped.
-
Field Details
-
INSERT
static final int INSERTThe trigger is called for INSERT statements.- See Also:
-
UPDATE
static final int UPDATEThe trigger is called for UPDATE statements.- See Also:
-
DELETE
static final int DELETEThe trigger is called for DELETE statements.- See Also:
-
SELECT
static final int SELECTThe trigger is called for SELECT statements.- See Also:
-
-
Method Details
-
init
default void init(Connection conn, String schemaName, String triggerName, String tableName, boolean before, int type) throws SQLException This method is called by the database engine once when initializing the trigger. It is called when the trigger is created, as well as when the database is opened. The type of operation is a bit field with the appropriate flags set. As an example, if the trigger is of type INSERT and UPDATE, then the parameter type is set to (INSERT | UPDATE).- Parameters:
conn
- a connection to the database (a system connection)schemaName
- the name of the schematriggerName
- the name of the trigger used in the CREATE TRIGGER statementtableName
- the name of the tablebefore
- whether the fire method is called before or after the operation is performedtype
- the operation type: INSERT, UPDATE, DELETE, SELECT, or a combination (this parameter is a bit field)- Throws:
SQLException
- on SQL exception
-
fire
This method is called for each triggered action. The method is called immediately when the operation occurred (before it is committed). A transaction rollback will also rollback the operations that were done within the trigger, if the operations occurred within the same database. If the trigger changes state outside the database, a rollback trigger should be used.The row arrays contain all columns of the table, in the same order as defined in the table.
The trigger itself may change the data in the newRow array.
- Parameters:
conn
- a connection to the databaseoldRow
- the old row, or null if no old row is available (for INSERT)newRow
- the new row, or null if no new row is available (for DELETE)- Throws:
SQLException
- if the operation must be undone
-
close
This method is called when the database is closed. If the method throws an exception, it will be logged, but closing the database will continue.- Throws:
SQLException
- on SQL exception
-
remove
This method is called when the trigger is dropped.- Throws:
SQLException
- on SQL exception
-