Open Source Repository

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



org/hibernate/usertype/UserType.java
//$Id: UserType.java 6133 2005-03-21 16:53:58Z turin42 $
package org.hibernate.usertype;

import java.io.Serializable;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import org.hibernate.HibernateException;

/**
 * This interface should be implemented by user-defined "types".
 * A "type" class is <em>not</em> the actual property type - it
 * is a class that knows how to serialize instances of another
 * class to and from JDBC.<br>
 <br>
 * This interface
 <ul>
 <li>abstracts user code from future changes to the <tt>Type</tt>
 * interface,</li>
 <li>simplifies the implementation of custom types and</li>
 <li>hides certain "internal" interfaces from user code.</li>
 </ul>
 <br>
 * Implementors must be immutable and must declare a public
 * default constructor.<br>
 <br>
 * The actual class mapped by a <tt>UserType</tt> may be just
 * about anything.<br>
 <br>
 <tt>CompositeUserType</tt> provides an extended version of
 * this interface that is useful for more complex cases.<br>
 <br>
 * Alternatively, custom types could implement <tt>Type</tt>
 * directly or extend one of the abstract classes in
 <tt>org.hibernate.type</tt>. This approach risks future
 * incompatible changes to classes or interfaces in that
 * package.
 *
 @see CompositeUserType for more complex cases
 @see org.hibernate.type.Type
 @author Gavin King
 */
public interface UserType {

  /**
   * Return the SQL type codes for the columns mapped by this type. The
   * codes are defined on <tt>java.sql.Types</tt>.
   @see java.sql.Types
   @return int[] the typecodes
   */
  public int[] sqlTypes();

  /**
   * The class returned by <tt>nullSafeGet()</tt>.
   *
   @return Class
   */
  public Class returnedClass();

  /**
   * Compare two instances of the class mapped by this type for persistence "equality".
   * Equality of the persistent state.
   *
   @param x
   @param y
   @return boolean
   */
  public boolean equals(Object x, Object ythrows HibernateException;

  /**
   * Get a hashcode for the instance, consistent with persistence "equality"
   */
  public int hashCode(Object xthrows HibernateException;

  /**
   * Retrieve an instance of the mapped class from a JDBC resultset. Implementors
   * should handle possibility of null values.
   *
   @param rs a JDBC result set
   @param names the column names
   @param owner the containing entity
   @return Object
   @throws HibernateException
   @throws SQLException
   */
  public Object nullSafeGet(ResultSet rs, String[] names, Object ownerthrows HibernateException, SQLException;

  /**
   * Write an instance of the mapped class to a prepared statement. Implementors
   * should handle possibility of null values. A multi-column type should be written
   * to parameters starting from <tt>index</tt>.
   *
   @param st a JDBC prepared statement
   @param value the object to write
   @param index statement parameter index
   @throws HibernateException
   @throws SQLException
   */
  public void nullSafeSet(PreparedStatement st, Object value, int indexthrows HibernateException, SQLException;

  /**
   * Return a deep copy of the persistent state, stopping at entities and at
   * collections. It is not necessary to copy immutable objects, or null
   * values, in which case it is safe to simply return the argument.
   *
   @param value the object to be cloned, which may be null
   @return Object a copy
   */
  public Object deepCopy(Object valuethrows HibernateException;

  /**
   * Are objects of this type mutable?
   *
   @return boolean
   */
  public boolean isMutable();

  /**
   * Transform the object into its cacheable representation. At the very least this
   * method should perform a deep copy if the type is mutable. That may not be enough
   * for some implementations, however; for example, associations must be cached as
   * identifier values. (optional operation)
   *
   @param value the object to be cached
   @return a cachable representation of the object
   @throws HibernateException
   */
  public Serializable disassemble(Object valuethrows HibernateException;

  /**
   * Reconstruct an object from the cacheable representation. At the very least this
   * method should perform a deep copy if the type is mutable. (optional operation)
   *
   @param cached the object to be cached
   @param owner the owner of the cached object
   @return a reconstructed object from the cachable representation
   @throws HibernateException
   */
  public Object assemble(Serializable cached, Object ownerthrows HibernateException;

  /**
   * During merge, replace the existing (target) value in the entity we are merging to
   * with a new (original) value from the detached entity we are merging. For immutable
   * objects, or null values, it is safe to simply return the first parameter. For
   * mutable objects, it is safe to return a copy of the first parameter. For objects
   * with component values, it might make sense to recursively replace component values.
   *
   @param original the value from the detached entity being merged
   @param target the value in the managed entity
   @return the value to be merged
   */
  public Object replace(Object original, Object target, Object ownerthrows HibernateException;
}