All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.ebean.config.dbplatform.DbIdentity Maven / Gradle / Ivy

package io.ebean.config.dbplatform;

/**
 * Defines the identity/sequence behaviour for the database.
 */
public class DbIdentity {

  private static final String TABLE_PLACEHOLDER = "{table}";

  /**
   * Set if this DB supports sequences. Note some DB's support both Sequences
   * and Identity.
   */
  private boolean supportsSequence;
  private boolean supportsIdentity;

  private boolean supportsGetGeneratedKeys;

  private String selectLastInsertedIdTemplate;

  private IdType idType = IdType.IDENTITY;

  public DbIdentity() {
  }

  /**
   * Return true if GetGeneratedKeys is supported.
   * 

* GetGeneratedKeys required to support JDBC batching transparently. *

*/ public boolean isSupportsGetGeneratedKeys() { return supportsGetGeneratedKeys; } /** * Set if GetGeneratedKeys is supported. */ public void setSupportsGetGeneratedKeys(boolean supportsGetGeneratedKeys) { this.supportsGetGeneratedKeys = supportsGetGeneratedKeys; } /** * Return the SQL query to find the SelectLastInsertedId. *

* This should only be set on databases that don't support GetGeneratedKeys. *

*/ public String getSelectLastInsertedId(String table) { if (selectLastInsertedIdTemplate == null) { return null; } return selectLastInsertedIdTemplate.replace(TABLE_PLACEHOLDER, table); } /** * Set the template used to build the SQL query to return the LastInsertedId. *

* The template can contain "{table}" where the table name should be include * in the sql query. *

*

* This should only be set on databases that don't support GetGeneratedKeys. *

*/ public void setSelectLastInsertedIdTemplate(String selectLastInsertedIdTemplate) { this.selectLastInsertedIdTemplate = selectLastInsertedIdTemplate; } /** * Return true if the database supports sequences. */ public boolean isSupportsSequence() { return supportsSequence; } /** * Set to true if the database supports sequences. Generally this also means * you want to set the default IdType to sequence (some DB's support both * sequences and identity). */ public void setSupportsSequence(boolean supportsSequence) { this.supportsSequence = supportsSequence; } /** * Return true if this DB platform supports identity (autoincrement). */ public boolean isSupportsIdentity() { return supportsIdentity; } /** * Set to true if this DB platform supports identity (autoincrement). */ public void setSupportsIdentity(boolean supportsIdentity) { this.supportsIdentity = supportsIdentity; } /** * Return the default ID generation type that should be used. This should be * either SEQUENCE or IDENTITY (aka Autoincrement). *

* Note: Id properties of type UUID automatically get a UUID generator * assigned to them. *

*/ public IdType getIdType() { return idType; } /** * Set the default ID generation type that should be used. */ public void setIdType(IdType idType) { this.idType = idType; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy