Skip navigation links

Oracle Fusion Middleware Java API Reference for Oracle TopLink
11g Release 1 (11.1.1)

E28847-01


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.

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

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.

Skip navigation links

Copyright © 1998, 2012, Oracle. All Rights Reserved.