Class PgTrigger

All Implemented Interfaces:
IHashable, ISearchPath, IStatement

public final class PgTrigger extends AbstractTrigger
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.
  • Constructor Details

    • PgTrigger

      public PgTrigger(String name)
      Creates a new PostgreSQL trigger.
      Parameters:
      name - trigger name
  • Method Details

    • getCreationSQL

      public void getCreationSQL(SQLScript script)
      Description copied from class: PgStatement
      Generates 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:
      getCreationSQL in class PgStatement
      Parameters:
      script - the SQL script to append creation statements to
    • appendAlterSQL

      public ObjectState appendAlterSQL(PgStatement newCondition, SQLScript script)
      Description copied from class: PgStatement
      Fill script with object changes and return change type
      Specified by:
      appendAlterSQL in class PgStatement
      Parameters:
      newCondition - new object state
      script - script to collect changes
      Returns:
      object change type
    • canDropBeforeCreate

      public boolean canDropBeforeCreate()
      Description copied from class: PgStatement
      Checks if this statement can be dropped before being recreated. Override in subclasses that support drop-before-create behavior.
      Overrides:
      canDropBeforeCreate in class PgStatement
      Returns:
      true if the statement can be dropped before recreation
    • setType

      public void setType(PgTrigger.TgTypes tgType)
    • setForEachRow

      public void setForEachRow(boolean isForEachRow)
    • setFunction

      public void setFunction(String function)
    • 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

      public void addUpdateColumn(String columnName)
      Adds a column name to the UPDATE OF clause.
      Parameters:
      columnName - column to monitor for updates
    • setWhen

      public void setWhen(String when)
    • setImmediate

      public void setImmediate(Boolean isImmediate)
    • setRefTableName

      public void setRefTableName(String refTableName)
    • setOldTable

      public void setOldTable(String oldTable)
    • setNewTable

      public void setNewTable(String newTable)
    • setTriggerState

      public void setTriggerState(TriggerState triggerState)
    • compare

      public boolean compare(PgStatement obj)
      Description copied from class: PgStatement
      This method does not account for nested child PgStatements. Shallow version of PgStatement.equals(Object)
      Overrides:
      compare in class PgStatement
    • computeHash

      public void computeHash(Hasher hasher)
      Description copied from interface: IHashable
      Computes the hash of the implementing object using the provided hasher. The implementation should call appropriate put methods on the hasher for all fields that should contribute to the hash value.
      Parameters:
      hasher - the hasher instance to use for hash computation