Package org.pgcodekeeper.core.schema.pg
Class PgTrigger
java.lang.Object
org.pgcodekeeper.core.schema.PgStatement
org.pgcodekeeper.core.schema.AbstractTrigger
org.pgcodekeeper.core.schema.pg.PgTrigger
- All Implemented Interfaces:
IHashable,ISearchPath,IStatement
PostgreSQL trigger implementation.
Triggers are functions that are automatically executed in response to database events
like INSERT, UPDATE, DELETE, or TRUNCATE on tables or views.
-
Nested Class Summary
Nested Classes -
Field Summary
Fields inherited from class org.pgcodekeeper.core.schema.PgStatement
GO -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidaddUpdateColumn(String columnName) Adds a column name to the UPDATE OF clause.appendAlterSQL(PgStatement newCondition, SQLScript script) Fill script with object changes and return change typebooleanChecks if this statement can be dropped before being recreated.booleancompare(PgStatement obj) This method does not account for nested child PgStatements.voidcomputeHash(Hasher hasher) Computes the hash of the implementing object using the provided hasher.voidgetCreationSQL(SQLScript script) Generates the SQL statements needed to create this database object.voidsetConstraint(boolean isConstraint) voidsetForEachRow(boolean isForEachRow) voidsetFunction(String function) voidsetImmediate(Boolean isImmediate) voidsetNewTable(String newTable) voidsetOldTable(String oldTable) voidsetOnDelete(boolean isOnDelete) voidsetOnInsert(boolean isOnInsert) voidsetOnTruncate(boolean isOnTruncate) voidsetOnUpdate(boolean isOnUpdate) voidsetRefTableName(String refTableName) voidsetTriggerState(TriggerState triggerState) voidsetType(PgTrigger.TgTypes tgType) voidMethods inherited from class org.pgcodekeeper.core.schema.AbstractTrigger
getContainingSchema, getStatementType, isSubElement, shallowCopyMethods inherited from class org.pgcodekeeper.core.schema.PgStatement
addAllDeps, addDep, addPrivilege, appendAlterComments, appendComments, appendOwnerSQL, canDrop, checkComments, clearPrivileges, compareChildren, deepCopy, equals, getAuthor, getBareName, getChildren, getComment, getDbType, getDeps, getDescendants, getDropSQL, getDropSQL, getLibName, getLocation, getName, getObjectState, getObjectState, getOwner, getParent, getPrivileges, getQualifiedName, getSQL, getTwin, getTypeName, hasChildren, hashCode, isLib, isOwned, setAuthor, setComment, setLibName, setLocation, setOwner, setParent, toStringMethods inherited from interface org.pgcodekeeper.core.schema.ISearchPath
getDatabase, getSchemaNameMethods inherited from interface org.pgcodekeeper.core.schema.IStatement
getBareName, getComment, getName, getParent, getQualifiedName
-
Constructor Details
-
PgTrigger
Creates a new PostgreSQL trigger.- Parameters:
name- trigger name
-
-
Method Details
-
getCreationSQL
Description copied from class:PgStatementGenerates the SQL statements needed to create this database object. This is an abstract method that must be implemented by subclasses to provide the specific CREATE SQL for each object type.- Specified by:
getCreationSQLin classPgStatement- Parameters:
script- the SQL script to append creation statements to
-
appendAlterSQL
Description copied from class:PgStatementFill script with object changes and return change type- Specified by:
appendAlterSQLin classPgStatement- Parameters:
newCondition- new object statescript- script to collect changes- Returns:
- object change type
-
canDropBeforeCreate
public boolean canDropBeforeCreate()Description copied from class:PgStatementChecks if this statement can be dropped before being recreated. Override in subclasses that support drop-before-create behavior.- Overrides:
canDropBeforeCreatein classPgStatement- Returns:
- true if the statement can be dropped before recreation
-
setType
-
setForEachRow
public void setForEachRow(boolean isForEachRow) -
setFunction
-
setOnDelete
public void setOnDelete(boolean isOnDelete) -
setOnInsert
public void setOnInsert(boolean isOnInsert) -
setOnUpdate
public void setOnUpdate(boolean isOnUpdate) -
setOnTruncate
public void setOnTruncate(boolean isOnTruncate) -
setConstraint
public void setConstraint(boolean isConstraint) -
addUpdateColumn
Adds a column name to the UPDATE OF clause.- Parameters:
columnName- column to monitor for updates
-
setWhen
-
setImmediate
-
setRefTableName
-
setOldTable
-
setNewTable
-
setTriggerState
-
compare
Description copied from class:PgStatementThis method does not account for nested child PgStatements. Shallow version ofPgStatement.equals(Object)- Overrides:
comparein classPgStatement
-
computeHash
Description copied from interface:IHashableComputes the hash of the implementing object using the provided hasher. The implementation should call appropriateputmethods on the hasher for all fields that should contribute to the hash value.- Parameters:
hasher- the hasher instance to use for hash computation
-