Class PgSequence

All Implemented Interfaces:
IRelation, ISearchPath, ISequence, IStatement, IHashable

public class PgSequence extends PgAbstractStatement implements ISequence
PostgreSQL sequence implementation. Sequences generate unique numeric identifiers, commonly used for auto-incrementing primary keys. Supports various data types, caching, cycling, and ownership by table columns.
  • Constructor Details

    • PgSequence

      public PgSequence(String name)
      Creates a new PostgreSQL sequence with default cache value of 1.
      Parameters:
      name - sequence name
  • Method Details

    • getCreationSQL

      public void getCreationSQL(SQLScript script)
      Description copied from interface: IStatement
      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 interface IStatement
      Parameters:
      script - the SQL script to append creation statements to
    • fillSequenceBody

      public void fillSequenceBody(StringBuilder sbSQL)
    • getOwnedBySQL

      public void getOwnedBySQL(SQLScript script)
      Creates SQL statement for modification "OWNED BY" parameter.
    • getOwnedBySQL

      public void getOwnedBySQL(SQLScript script, SQLActionType type)
    • appendAlterSQL

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

      public void setMinMaxInc(long inc, Long max, Long min, String dataType, long precision)
    • setStartWith

      public void setStartWith(String startWith)
    • getOwnedBy

      public ObjectReference getOwnedBy()
      Gets the table column that owns this sequence.
      Returns:
      column reference or null if not owned
    • setOwnedBy

      public void setOwnedBy(ObjectReference ownedBy)
    • setDataType

      public void setDataType(String dataType)
    • getDataType

      public String getDataType()
    • isLogged

      public boolean isLogged()
      Checks if this sequence is logged (written to WAL).
      Returns:
      true if logged, false if unlogged
    • setLogged

      public void setLogged(boolean isLogged)
    • setCycle

      public void setCycle(boolean cycle)
    • setCache

      public void setCache(String cache)
    • getRelationColumns

      public Stream<Pair<String,String>> getRelationColumns()
      Description copied from interface: IRelation
      Gets the columns of this relation as name-type pairs.
      Specified by:
      getRelationColumns in interface IRelation
      Returns:
      a stream of column name and type pairs
    • 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.
      Specified by:
      computeHash in interface IHashable
      Parameters:
      hasher - the hasher instance to use for hash computation
    • compare

      public boolean compare(IStatement obj)
      Description copied from class: AbstractStatement
      This method does not account for nested child PgStatements. Shallow version of AbstractStatement.equals(Object)
      Specified by:
      compare in interface IStatement
      Overrides:
      compare in class AbstractStatement