Open Source Repository

Home /hibernate/hibernate-3.2.4.ga | Repository Home



org/hibernate/id/PersistentIdentifierGenerator.java
//$Id: PersistentIdentifierGenerator.java 6514 2005-04-26 06:37:54Z oneovthafew $
package org.hibernate.id;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.hibernate.HibernateException;
import org.hibernate.dialect.Dialect;

/**
 * An <tt>IdentifierGenerator</tt> that requires creation of database objects.
 <br><br>
 * All <tt>PersistentIdentifierGenerator</tt>s that also implement
 <tt>Configurable</tt> have access to a special mapping parameter: schema
 *
 @see IdentifierGenerator
 @see Configurable
 @author Gavin King
 */
public interface PersistentIdentifierGenerator extends IdentifierGenerator {

  /**
   * The configuration parameter holding the schema name
   */
  public static final String SCHEMA = "schema";

  /**
   * The configuration parameter holding the table name for the
   * generated id
   */
  public static final String TABLE = "target_table";

  /**
   * The configuration parameter holding the table names for all
   * tables for which the id must be unique
   */
  public static final String TABLES = "identity_tables";

  /**
   * The configuration parameter holding the primary key column
   * name of the generated id
   */
  public static final String PK = "target_column";

    /**
     * The configuration parameter holding the catalog name
     */
    public static final String CATALOG = "catalog";
    
  /**
   * The SQL required to create the underlying database objects.
   @param dialect
   @return String[]
   @throws HibernateException
   */
  public String[] sqlCreateStrings(Dialect dialectthrows HibernateException;

  /**
   * The SQL required to remove the underlying database objects.
   @param dialect
   @return String
   @throws HibernateException
   */
  public String[] sqlDropStrings(Dialect dialectthrows HibernateException;

  /**
   * Return a key unique to the underlying database objects. Prevents us from
   * trying to create/remove them multiple times.
   @return Object an identifying key for this generator
   */
  public Object generatorKey();
  
  static final Log SQL = LogFactory.getLog("org.hibernate.SQL");

}