Module eclipselink

Annotation Interface ClassExtractor


@Target(TYPE) @Retention(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: 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 InheritanceType.SINGLE_TABLE and InheritanceType.JOINED inheritance strategies.

If a ClassExtractor is used then a DiscriminatorColumn cannot be used. A DiscriminatorColumn also cannot be used on either the root or its subclasses.

In addition, for more complex configurations using a ClassExtractor and an InheritanceType.SINGLE_TABLE strategy, the descriptor's withAllSubclasses and onlyInstances expressions should be set through the ClassExtractor's initialize method.

See Also:
Author:
Guy Pelletier
  • Required Element Summary

    Required Elements
    Modifier and Type
    Required Element
    Description
    Defines the name of the class extractor that should be applied to this entity's descriptor.
  • Element Details

    • value

      Class<?> value
      Defines the name of the class extractor that should be applied to this entity's descriptor.