Open Source Repository

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



org/hibernate/type/AssociationType.java
//$Id: AssociationType.java 7017 2005-06-05 04:31:34Z oneovthafew $
package org.hibernate.type;

import org.hibernate.MappingException;
import org.hibernate.engine.SessionFactoryImplementor;
import org.hibernate.persister.entity.Joinable;

import java.util.Map;

/**
 * A type that represents some kind of association between entities.
 @see org.hibernate.engine.Cascade
 @author Gavin King
 */
public interface AssociationType extends Type {

  /**
   * Get the foreign key directionality of this association
   */
  public ForeignKeyDirection getForeignKeyDirection();

  //TODO: move these to a new JoinableType abstract class,
  //extended by EntityType and PersistentCollectionType:

  /**
   * Is the primary key of the owning entity table
   * to be used in the join?
   */
  public boolean useLHSPrimaryKey();
  /**
   * Get the name of a property in the owning entity 
   * that provides the join key (null if the identifier)
   */
  public String getLHSPropertyName();
  
  /**
   * The name of a unique property of the associated entity 
   * that provides the join key (null if the identifier of
   * an entity, or key of a collection)
   */
  public String getRHSUniqueKeyPropertyName();

  /**
   * Get the "persister" for this association - a class or
   * collection persister
   */
  public Joinable getAssociatedJoinable(SessionFactoryImplementor factorythrows MappingException;
  
  /**
   * Get the entity name of the associated entity
   */
  public String getAssociatedEntityName(SessionFactoryImplementor factorythrows MappingException;
  
  /**
   * Get the "filtering" SQL fragment that is applied in the 
   * SQL on clause, in addition to the usual join condition
   */  
  public String getOnCondition(String alias, SessionFactoryImplementor factory, Map enabledFilters
  throws MappingException;
  
  /**
   * Do we dirty check this association, even when there are
   * no columns to be updated?
   */
  public abstract boolean isAlwaysDirtyChecked();
  
  public boolean isEmbeddedInXML();
}