EclipseLink 2.2.0, build 'v20110202-r8913' API Reference

org.eclipse.persistence.annotations
Annotation Type ClassExtractor


@Target(value=TYPE)
@Retention(value=RUNTIME)
public @interface ClassExtractor

A ClassExtractor allows for a user defined class indicator in place of providing a discriminator column. The class has the following restrictions: - It must extend the org.eclipse.persistence.descriptors.ClassExtractor class and implement the extractClassFromRow(Record, Session) method. - That method must take a database row (a Record/Map) as an argument and must return the class to use for that row. This method will be used to decide which class to instantiate when reading from the database. It is the application's responsibility to populate any typing information in the database required to determine the class from the row. The ClassExtractor must only be set on the root of an entity class or sub-hierarchy in which a different inheritance strategy is applied. The ClassExtractor can only be used with the SINGLE_TABLE and JOINED inheritance strategies. If a ClassExtractor is used then a DiscriminatorColumn cannot be used. A ClassExtractor also cannot be used on either the root or its subclasses. In addition, for more complex configurations using a ClassExtractor and a SINGLE_TABLE strategy, the descriptor's withAllSubclasses and onlyInstances expressions should be set through the ClassExtractor's initialize method.

See Also:
org.eclipse.persistence.descriptors.InheritancePolicy.setWithAllSubclassesExpression(Expression), org.eclipse.persistence.descriptors.InheritancePolicy.setOnlyInstancesExpression(Expression)
Author:
Guy Pelletier
Since:
EclipseLink 2.1

Required Element Summary
 java.lang.Class value
          (Required) Defines the name of the class extractor that should be applied to this entity's descriptor.
 

Element Detail

value

public abstract java.lang.Class value
(Required) Defines the name of the class extractor that should be applied to this entity's descriptor.


EclipseLink 2.2.0, build 'v20110202-r8913' API Reference