Class InheritancePolicy
java.lang.Object
org.eclipse.persistence.core.descriptors.CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,org.eclipse.persistence.internal.sessions.AbstractSession,ClassDescriptor,org.eclipse.persistence.internal.helper.DatabaseField>
   
org.eclipse.persistence.descriptors.InheritancePolicy
- All Implemented Interfaces:
- Serializable,- Cloneable
public class InheritancePolicy
extends CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,org.eclipse.persistence.internal.sessions.AbstractSession,ClassDescriptor,org.eclipse.persistence.internal.helper.DatabaseField>
implements Serializable, Cloneable   
Purpose: Allows customization of an object's inheritance. The primary supported inheritance model uses a class type indicator column in the table that stores the object's class type. The class-to-type mapping is specified on this policy. The full class name can also be used for the indicator instead of the mapping.
Each subclass can either share their parents table, or in addition add their own table(s).
For legacy models a customized inheritance class-extractor can be provided. This allows Java code to be used to compute the class type to use for a row. When this customized inheritance model is used an only-instances and with-all-subclasses filter expression may be required for concrete and branch querying.
- See Also:
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected Vectorprotected List<ClassDescriptor>protected Expressionprotected List<org.eclipse.persistence.internal.helper.DatabaseTable>protected Map<org.eclipse.persistence.internal.helper.DatabaseTable,Expression> protected ClassExtractorprotected StringAllow for class extraction method to be specified.protected org.eclipse.persistence.internal.helper.DatabaseFieldprotected Mapprotected Mapprotected booleanprotected ClassDescriptorprotected booleanprotected Expressionprotected Classprotected Stringprotected ClassDescriptorprotected org.eclipse.persistence.internal.helper.DatabaseTableprotected ClassDescriptorPERF: Cache root descriptor.protected booleanprotected booleanDefine if an outer join should be used to read subclasses.protected Booleanprotected booleanprotected booleanprotected Expression
- 
Constructor SummaryConstructorsConstructorDescriptionINTERNAL: Create a new policy.InheritancePolicy(ClassDescriptor descriptor) INTERNAL: Create a new policy.
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddChildDescriptor(ClassDescriptor childDescriptor) INTERNAL: Add child descriptor to the parent descriptor.protected voidaddChildTableJoinExpression(org.eclipse.persistence.internal.helper.DatabaseTable table, Expression expression) INTERNAL: childrenTablesJoinExpressions, childrenTables, allTables and childrenJoinExpression are created simultaneously and kept in sync.voidaddChildTableJoinExpressionToAllParents(org.eclipse.persistence.internal.helper.DatabaseTable table, Expression expression) INTERNAL: call addChildTableJoinExpression on all parentsvoidaddClassIndicator(Class childClass, Object typeValue) PUBLIC: Add a class indicator for the root classes subclass.voidaddClassIndicatorFieldToInsertRow(org.eclipse.persistence.internal.sessions.AbstractRecord databaseRow) INTERNAL: Add abstract class indicator information to the database row.voidaddClassIndicatorFieldToRow(org.eclipse.persistence.internal.sessions.AbstractRecord databaseRow) INTERNAL: Add abstract class indicator information to the database row.protected voidaddClassIndicatorTypeToParent(Object indicator) INTERNAL: Post initialize the child descriptorsvoidaddClassNameIndicator(String childClassName, Object typeValue) INTERNAL: Add the class name reference by class name, used by the MW.protected voidaddFieldsToParent(Vector fields) INTERNAL: Recursively adds fields to all the parentsvoidappendWithAllSubclassesExpression(org.eclipse.persistence.internal.expressions.SQLSelectStatement selectStatement) INTERNAL: Append the branch with all subclasses expression to the statement.org.eclipse.persistence.internal.expressions.SQLSelectStatementINTERNAL: Return a select statement that will be used to query the class indicators required to query.org.eclipse.persistence.internal.expressions.SQLSelectStatementINTERNAL: Build a select statement for all subclasses on the view using the same selection criteria as the query.classFromRow(org.eclipse.persistence.internal.sessions.AbstractRecord rowFromDatabase, org.eclipse.persistence.internal.sessions.AbstractSession session) INTERNAL: This method is invoked only for the abstract descriptors.classFromValue(Object classFieldValue, org.eclipse.persistence.internal.sessions.AbstractSession session) INTERNAL: This method is used to turn the a raw database field value classFieldValue into a Class object.clone()INTERNAL: Clone the policyvoidconvertClassNamesToClasses(ClassLoader classLoader) INTERNAL: Convert all the class-name-based settings in this InheritancePolicy to actual class-based settings.protected <T> Class<T>convertClassNameToClass(String className, ClassLoader classLoader) INTERNAL: Convert the given className to an actual class.voidPUBLIC: Set the descriptor to only read instance of itself when queried.voidPUBLIC: Set the descriptor not to use the class' full name as the indicator.INTERNAL: Stores class indicators for all child and children's children.INTERNAL: Returns all the child descriptors, even descriptors for subclasses of subclasses.protected List<ClassDescriptor>getAllChildDescriptors(List<ClassDescriptor> allChildDescriptors) INTERNAL: Recursive subroutine of getAllChildDescriptors.INTERNAL: all tables for reference class plus childrenTablesINTERNAL: Return all the immediate child descriptors.INTERNAL: all expressions from childrenTablesJoinExpressions ANDed togetherList<org.eclipse.persistence.internal.helper.DatabaseTable>INTERNAL: if reads subclasses, all tables for all read subclasses (indirect included).Map<org.eclipse.persistence.internal.helper.DatabaseTable,Expression> INTERNAL: join expression for each child table, keyed by the tableprotected MethodINTERNAL: Return all the classExtractionMethodADVANCED: A class extraction method can be registered with the descriptor to override the default inheritance mechanism.ADVANCED: A class extractor can be registered with the descriptor to override the default inheritance mechanism.INTERNAL: Return the class indicator associations for XML.org.eclipse.persistence.internal.helper.DatabaseFieldINTERNAL: Returns field that the class type indicator is store when using inheritance.PUBLIC: Return the class indicator field name.INTERNAL: Return the association of indicators and classes using specified ConversionManagerprotected ObjectINTERNAL: Returns value of the abstract class indicator for the Java class.protected ObjectgetClassIndicatorValue(Class javaClass) INTERNAL: Returns the indicator field value for the given class If no abstract indicator mapping is specified, use the class name.INTERNAL: Return the mapping from class name to indicator, used by MW.booleanADVANCED: Determines whether the descriptors using this inheritance policy should be used as descriptors for subclasses of the classes they describe if those subclasses do not have their own descriptor e.g.INTERNAL: Returns the descriptor which the policy belongs to.getDescriptor(Class theClass) INTERNAL: Returns descriptor corresponding to the class owning the policy or its subclass - otherwise null.ADVANCED: Return the 'only instances expression'.PUBLIC: Return the parent class.INTERNAL: Return the parent class name.INTERNAL: Return the parent descriptor.org.eclipse.persistence.internal.helper.DatabaseTableINTERNAL: The view can be used to optimize/customize the query for all subclasses where they have multiple tables.ADVANCED: The view can be used to optimize/customize the query for all subclasses where they have multiple tables.INTERNAL: Return the root parent descriptorgetSubclassDescriptor(Class theClass) INTERNAL: use aggregate in inheritancebooleanINTERNAL: return if we should use the descriptor inheritance to determine if an object can be returned from the identity map or not.ADVANCED: Return the Expression which gets all subclasses.booleanINTERNAL: Check if descriptor has childrenbooleanINTERNAL:booleanINTERNAL: Checks if the class is involved in inheritancebooleanINTERNAL: Return if any children of this descriptor require information from another table not specified at the parent level.booleanhasView()INTERNAL: Return if a view is used for inheritance reads.voidinitialize(org.eclipse.persistence.internal.sessions.AbstractSession session) INTERNAL: Initialize the inheritance properties of the descriptor once the mappings are initialized.protected voidINTERNAL: Potentially override the cache invalidation behaviorprotected voidinitializeClassExtractor(org.eclipse.persistence.internal.sessions.AbstractSession session) INTERNAL: Setup the default classExtractionMethod, or if one was specified by the user make sure it is valid.protected voidINTERNAL: Initialize the expression to use to check the specific type field.protected voidINTERNAL: Potentially override the optimistic locking behaviorprotected voidINTERNAL: Initialize the expression to use for queries to the class and its subclasses.booleanINTERNAL: Check if it is a child descriptor.booleanINTERNAL: Indicate whether a single table or joined inheritance strategy is being used.booleanINTERNAL: Return whether or not is root parent descriptorvoidpostInitialize(org.eclipse.persistence.internal.sessions.AbstractSession session) INTERNAL: Initialized the inheritance properties that cannot be initialized until after the mappings have been.voidpreInitialize(org.eclipse.persistence.internal.sessions.AbstractSession session) INTERNAL: Allow the inheritance properties of the descriptor to be initialized.voidPUBLIC: Set the descriptor to read instance of itself and its subclasses when queried.voidremoteInitialization(DistributedSession session) INTERNAL: Used to initialize a remote descriptor.protected voidremoveChildren(ClassDescriptor descriptor, Set<Class> classes, Set<Class> subclasses) Remove all of the subclasses (and so on) from the set of classes.booleanINTERNAL: Return if this descriptor has children that define additional tables and needs to read them.protected VectorINTERNAL: Select all rows from a abstract table descriptor.protected VectorINTERNAL: Select all rows from a abstract table descriptor.INTERNAL: Select all rows from a abstract table descriptor.protected org.eclipse.persistence.internal.sessions.AbstractRecordINTERNAL: Select one rows from a abstract table descriptor.protected org.eclipse.persistence.internal.sessions.AbstractRecordINTERNAL: Select one row of any concrete subclass, This must use two selects, the first retrieves the type field only.org.eclipse.persistence.internal.sessions.AbstractRecordINTERNAL: Select one row of any concrete subclass, This must use two selects, the first retrieves the type field only.protected voidsetAllChildClassIndicators(Vector allChildClassIndicators) INTERNAL:voidsetAlwaysUseOuterJoinForClassType(boolean choice) PUBLIC: Sets the inheritance policy to always use an outer join when querying across a relationship of class.voidsetChildDescriptors(List<ClassDescriptor> childDescriptors) INTERNAL:voidsetClassExtractionMethodName(String staticClassClassExtractionMethod) ADVANCED: A class extraction method can be registered with the descriptor to override the default inheritance mechanism.voidsetClassExtractor(ClassExtractor classExtractor) ADVANCED: A class extractor can be registered with the descriptor to override the default inheritance mechanism.voidsetClassExtractorName(String classExtractorName) ADVANCED: Set the class extractor class name.voidsetClassIndicatorAssociations(Vector classIndicatorAssociations) INTERNAL: Set the class indicator associations from reading the deployment XML.voidsetClassIndicatorField(org.eclipse.persistence.internal.helper.DatabaseField classIndicatorField) ADVANCED: To set the class indicator field.voidsetClassIndicatorFieldName(String fieldName) PUBLIC: To set the class indicator field name.voidsetClassIndicatorMapping(Map classIndicatorMapping) PUBLIC: Set the association of indicators and classes.voidsetClassNameIndicatorMapping(Map classNameIndicatorMapping) INTERNAL: Set the class name indicator mapping, used by the MW.voidsetDescribesNonPersistentSubclasses(boolean describesNonPersistentSubclasses) ADVANCED: Determines whether the descriptors using this inheritance policy should be used as descriptors for subclasses of the classes they describe if those subclasses do not have their own descriptor e.g.voidsetDescriptor(ClassDescriptor descriptor) INTERNAL: Set the descriptor.voidINTERNAL: Used to indicate a JOINED inheritance strategy.voidsetOnlyInstancesExpression(Expression onlyInstancesExpression) ADVANCED: Sets the expression used to select instance of the class only.voidsetParentClass(Class parentClass) PUBLIC: Set the parent class.voidsetParentClassName(String parentClassName) INTERNAL: Set the parent class name, used by MW to avoid referencing the real class for deployment XML generation.voidsetParentDescriptor(ClassDescriptor parentDescriptor) INTERNAL:protected voidsetReadAllSubclassesView(org.eclipse.persistence.internal.helper.DatabaseTable readAllSubclassesView) INTERNAL: The view can be used to optimize/customize the query for all subclasses where they have multiple tables.voidsetReadAllSubclassesViewName(String readAllSubclassesViewName) ADVANCED: The view can be used to optimize/customize the query for all subclasses where they have multiple tables.voidsetShouldOuterJoinSubclasses(boolean shouldOuterJoinSubclasses) PUBLIC: Set if an outer join should be used to read subclasses.voidsetShouldReadSubclasses(boolean shouldReadSubclasses) PUBLIC: Set the descriptor to read instance of itself and its subclasses when queried.voidsetShouldReadSubclasses(Boolean shouldReadSubclasses) INTERNAL: Set the descriptor to read instance of itself and its subclasses when queried.voidsetShouldUseClassNameAsIndicator(boolean shouldUseClassNameAsIndicator) PUBLIC: Set if the descriptor uses the classes fully qualified name as the indicator.voidINTERNAL: Used to indicate a SINGLE_TABLE inheritance strategy.voidsetUseDescriptorsToValidateInheritedObjects(boolean useDescriptorsToValidateInheritedObjects) INTERNAL: Sets if we should use the descriptor inheritance to determine if an object can be returned from the identity map or not.voidsetWithAllSubclassesExpression(Expression withAllSubclassesExpression) ADVANCED: Sets the expression to be used for querying for a class and all its subclasses.booleanPUBLIC: returns if the inheritance policy will always use an outerjoin when selecting class typebooleanPUBLIC: Return if an outer join should be used to read subclasses.booleanPUBLIC: Return true if this descriptor should read instances of itself and subclasses on queries.INTERNAL: Return true if this descriptor should read instances of itself and subclasses on queries.booleanPUBLIC: Return true if the descriptor use the classes full name as the indicator.toString()INTERNAL:protected voidINTERNAL: set the tables on the child descriptor overridden in org.eclipse.persistence.internal.oxm.QNameInheritancePolicyvoidPUBLIC: Set the descriptor to use the classes full name as the indicator.
- 
Field Details- 
parentClass
- 
parentClassName
- 
parentDescriptor
- 
childDescriptors
- 
classIndicatorFieldprotected org.eclipse.persistence.internal.helper.DatabaseField classIndicatorField
- 
classIndicatorMapping
- 
classNameIndicatorMapping
- 
shouldUseClassNameAsIndicatorprotected transient boolean shouldUseClassNameAsIndicator
- 
shouldReadSubclasses
- 
readAllSubclassesViewprotected org.eclipse.persistence.internal.helper.DatabaseTable readAllSubclassesView
- 
allChildClassIndicators
- 
onlyInstancesExpression
- 
withAllSubclassesExpression
- 
allTables
- 
childrenTables
- 
childrenTablesJoinExpressionsprotected transient Map<org.eclipse.persistence.internal.helper.DatabaseTable,Expression> childrenTablesJoinExpressions
- 
childrenJoinExpression
- 
classExtractorNameAllow for class extraction method to be specified.
- 
classExtractor
- 
descriptor
- 
shouldAlwaysUseOuterJoinprotected boolean shouldAlwaysUseOuterJoin
- 
useDescriptorsToValidateInheritedObjectsprotected boolean useDescriptorsToValidateInheritedObjects
- 
shouldOuterJoinSubclassesprotected boolean shouldOuterJoinSubclassesDefine if an outer join should be used to read subclasses.
- 
isJoinedStrategyprotected boolean isJoinedStrategy
- 
rootParentDescriptorPERF: Cache root descriptor.
- 
describesNonPersistentSubclassesprotected boolean describesNonPersistentSubclasses
 
- 
- 
Constructor Details- 
InheritancePolicypublic InheritancePolicy()INTERNAL: Create a new policy. Only descriptors involved in inheritance should have a policy.
- 
InheritancePolicyINTERNAL: Create a new policy. Only descriptors involved in inheritance should have a policy.
 
- 
- 
Method Details- 
addChildDescriptorINTERNAL: Add child descriptor to the parent descriptor.
- 
addChildTableJoinExpressionprotected void addChildTableJoinExpression(org.eclipse.persistence.internal.helper.DatabaseTable table, Expression expression) INTERNAL: childrenTablesJoinExpressions, childrenTables, allTables and childrenJoinExpression are created simultaneously and kept in sync.
- 
addChildTableJoinExpressionToAllParentspublic void addChildTableJoinExpressionToAllParents(org.eclipse.persistence.internal.helper.DatabaseTable table, Expression expression) INTERNAL: call addChildTableJoinExpression on all parents
- 
addClassIndicatorPUBLIC: Add a class indicator for the root classes subclass. The indicator is used to determine the class to use for a row read from the database, and to query only instances of a class from the database. Every concrete persistent subclass must have a single unique indicator defined for it. If the root class is concrete then it must also define an indicator. Only the root class's descriptor of the entire inheritance hierarchy can define the class indicator mapping.
- 
addClassNameIndicatorINTERNAL: Add the class name reference by class name, used by the MW.- Specified by:
- addClassNameIndicatorin class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
addClassIndicatorFieldToInsertRowpublic void addClassIndicatorFieldToInsertRow(org.eclipse.persistence.internal.sessions.AbstractRecord databaseRow) INTERNAL: Add abstract class indicator information to the database row. This is required when building a row for an insert or an update of a concrete child descriptor. This is only used to build a template row.
- 
addClassIndicatorFieldToRowpublic void addClassIndicatorFieldToRow(org.eclipse.persistence.internal.sessions.AbstractRecord databaseRow) INTERNAL: Add abstract class indicator information to the database row. This is required when building a row for an insert or an update of a concrete child descriptor.- Specified by:
- addClassIndicatorFieldToRowin class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
addClassIndicatorTypeToParentINTERNAL: Post initialize the child descriptors
- 
addFieldsToParentINTERNAL: Recursively adds fields to all the parents
- 
buildClassIndicatorSelectStatementpublic org.eclipse.persistence.internal.expressions.SQLSelectStatement buildClassIndicatorSelectStatement(ObjectLevelReadQuery query) INTERNAL: Return a select statement that will be used to query the class indicators required to query. This is used in the abstract-multiple read.
- 
appendWithAllSubclassesExpressionpublic void appendWithAllSubclassesExpression(org.eclipse.persistence.internal.expressions.SQLSelectStatement selectStatement) INTERNAL: Append the branch with all subclasses expression to the statement.
- 
buildViewSelectStatementpublic org.eclipse.persistence.internal.expressions.SQLSelectStatement buildViewSelectStatement(ObjectLevelReadQuery query) INTERNAL: Build a select statement for all subclasses on the view using the same selection criteria as the query.
- 
classFromRowpublic Class classFromRow(org.eclipse.persistence.internal.sessions.AbstractRecord rowFromDatabase, org.eclipse.persistence.internal.sessions.AbstractSession session) throws DescriptorException INTERNAL: This method is invoked only for the abstract descriptors.- Specified by:
- classFromRowin class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
- Throws:
- DescriptorException
 
- 
classFromValuepublic Class classFromValue(Object classFieldValue, org.eclipse.persistence.internal.sessions.AbstractSession session) throws DescriptorException INTERNAL: This method is used to turn the a raw database field value classFieldValue into a Class object. Used to determine which class objects to build from database results, and for class type expression- Throws:
- DescriptorException
 
- 
cloneINTERNAL: Clone the policy
- 
convertClassNamesToClassesINTERNAL: Convert all the class-name-based settings in this InheritancePolicy to actual class-based settings. This method is used when converting a project that has been built with class names to a project with classes. It will also convert referenced classes to the versions of the classes from the classLoader.
- 
convertClassNameToClassINTERNAL: Convert the given className to an actual class.
- 
dontReadSubclassesOnQueriespublic void dontReadSubclassesOnQueries()PUBLIC: Set the descriptor to only read instance of itself when queried. This is used with inheritance to configure the result of queries. By default this is true for root inheritance descriptors, and false for all others.
- 
dontUseClassNameAsIndicatorpublic void dontUseClassNameAsIndicator()PUBLIC: Set the descriptor not to use the class' full name as the indicator. The class indicator is used with inheritance to determine the class from a row. By default a class indicator mapping is required, this can be set to true if usage of the class name is desired. The field must be of a large enough size to store the fully qualified class name.
- 
getAllChildClassIndicatorsINTERNAL: Stores class indicators for all child and children's children. Used for queries on branch classes only.
- 
getAllChildDescriptorsINTERNAL: Returns all the child descriptors, even descriptors for subclasses of subclasses. Required for bug 3019934.- Specified by:
- getAllChildDescriptorsin class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
getAllChildDescriptorsINTERNAL: Recursive subroutine of getAllChildDescriptors.
- 
getChildrenTablesINTERNAL: if reads subclasses, all tables for all read subclasses (indirect included).
- 
getChildrenTablesJoinExpressionspublic Map<org.eclipse.persistence.internal.helper.DatabaseTable,Expression> getChildrenTablesJoinExpressions()INTERNAL: join expression for each child table, keyed by the table
- 
getChildrenJoinExpressionINTERNAL: all expressions from childrenTablesJoinExpressions ANDed together
- 
getAllTablesINTERNAL: all tables for reference class plus childrenTables
- 
getChildDescriptorsINTERNAL: Return all the immediate child descriptors. Only descriptors from direct subclasses are returned.
- 
getClassExtractionMethodINTERNAL: Return all the classExtractionMethod
- 
getClassExtractionMethodNameADVANCED: A class extraction method can be registered with the descriptor to override the default inheritance mechanism. This allows for a user defined class indicator in place of providing an explicit class indicator field. The method registered must be a static method on the class which has that descriptor. The method must take a Record as an argument (for example, a DatabaseRecord), and must return the class to use for that record. 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 record. If this method is used, then the class indicator field and mapping cannot be used, and in addition, the descriptor's withAllSubclasses and onlyInstances expressions must also be setup correctly.
- 
getClassExtractorADVANCED: A class extractor can be registered with the descriptor to override the default inheritance mechanism. This allows for a user defined class indicator in place of providing an explicit class indicator field. The instance registered must extend the ClassExtractor class and implement the extractClass(Map) method. The method must take 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, such as usage of a direct or transformation mapping for the type fields. If this method is used then the class indicator field and mapping cannot be used, and in addition, the descriptor's withAllSubclasses and onlyInstances expressions must also be setup correctly.
- 
setClassExtractorADVANCED: A class extractor can be registered with the descriptor to override the default inheritance mechanism. This allows for a user defined class indicator in place of providing an explicit class indicator field. The instance registered must extend the ClassExtractor class and implement the extractClass(Map) method. The method must take 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, such as usage of a direct or transformation mapping for the type fields. If this method is used then the class indicator field and mapping cannot be used, and in addition, the descriptor's withAllSubclasses and onlyInstances expressions must also be setup correctly.
- 
setClassExtractorNameADVANCED: Set the class extractor class name. At descriptor initialize time this class will be converted to a Class and set as the ClassExtractor. This method is called from JPA.- Specified by:
- setClassExtractorNamein class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
- See Also:
 
- 
getClassIndicatorAssociationsINTERNAL: Return the class indicator associations for XML. List of class-name/value associations.
- 
getClassIndicatorFieldpublic org.eclipse.persistence.internal.helper.DatabaseField getClassIndicatorField()INTERNAL: Returns field that the class type indicator is store when using inheritance.- Specified by:
- getClassIndicatorFieldin class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
getClassIndicatorFieldNamePUBLIC: Return the class indicator field name. This is the name of the field in the table that stores what type of object this is.- Specified by:
- getClassIndicatorFieldNamein class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
getClassIndicatorMappingINTERNAL: Return the association of indicators and classes using specified ConversionManager- Specified by:
- getClassIndicatorMappingin class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
getClassNameIndicatorMappingINTERNAL: Return the mapping from class name to indicator, used by MW.- Specified by:
- getClassNameIndicatorMappingin class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
getClassIndicatorValueINTERNAL: Returns value of the abstract class indicator for the Java class.
- 
getClassIndicatorValueINTERNAL: Returns the indicator field value for the given class If no abstract indicator mapping is specified, use the class name.
- 
getDescriptorINTERNAL: Returns the descriptor which the policy belongs to.- Specified by:
- getDescriptorin class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
getDescribesNonPersistentSubclassespublic boolean getDescribesNonPersistentSubclasses()ADVANCED: Determines whether the descriptors using this inheritance policy should be used as descriptors for subclasses of the classes they describe if those subclasses do not have their own descriptor e.g. If Employee.class has a descriptor and EmployeeSubClass does not have a descriptor, if describesNonPersistenceSubclasses is true Employee's descriptor will be used as the descriptor for Employee
- 
getOnlyInstancesExpressionADVANCED: Return the 'only instances expression'.
- 
getParentClassPUBLIC: Return the parent class.- Specified by:
- getParentClassin class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
getParentClassNameINTERNAL: Return the parent class name.
- 
getParentDescriptorINTERNAL: Return the parent descriptor.- Specified by:
- getParentDescriptorin class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
getReadAllSubclassesViewpublic org.eclipse.persistence.internal.helper.DatabaseTable getReadAllSubclassesView()INTERNAL: The view can be used to optimize/customize the query for all subclasses where they have multiple tables. This view can do the outer join, we require the view because we cannot generate dynamic platform independent SQL for outer joins (i.e. not possible to do so either).
- 
getReadAllSubclassesViewNameADVANCED: The view can be used to optimize/customize the query for all subclasses where they have multiple tables. This view can use outer joins or unions to combine the results of selecting from all of the subclass tables. If a view is not given then TopLink must make an individual call for each subclass.
- 
getRootParentDescriptorINTERNAL: Return the root parent descriptor
- 
getSubclassDescriptorINTERNAL: use aggregate in inheritance
- 
getDescriptorINTERNAL: Returns descriptor corresponding to the class owning the policy or its subclass - otherwise null.
- 
getUseDescriptorsToValidateInheritedObjectspublic boolean getUseDescriptorsToValidateInheritedObjects()INTERNAL: return if we should use the descriptor inheritance to determine if an object can be returned from the identity map or not.
- 
getWithAllSubclassesExpressionADVANCED: Return the Expression which gets all subclasses.
- 
hasChildrenpublic boolean hasChildren()INTERNAL: Check if descriptor has children
- 
hasClassExtractorpublic boolean hasClassExtractor()INTERNAL:- Specified by:
- hasClassExtractorin class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
hasClassIndicatorpublic boolean hasClassIndicator()INTERNAL: Checks if the class is involved in inheritance
- 
hasMultipleTableChildpublic boolean hasMultipleTableChild()INTERNAL: Return if any children of this descriptor require information from another table not specified at the parent level.
- 
hasViewpublic boolean hasView()INTERNAL: Return if a view is used for inheritance reads.
- 
initializepublic void initialize(org.eclipse.persistence.internal.sessions.AbstractSession session) INTERNAL: Initialize the inheritance properties of the descriptor once the mappings are initialized. This is done before formal postInitialize during the end of mapping initialize.
- 
initializeClassExtractorprotected void initializeClassExtractor(org.eclipse.persistence.internal.sessions.AbstractSession session) throws DescriptorException INTERNAL: Setup the default classExtractionMethod, or if one was specified by the user make sure it is valid.- Throws:
- DescriptorException
 
- 
initializeOnlyInstancesExpressionINTERNAL: Initialize the expression to use to check the specific type field.- Throws:
- DescriptorException
 
- 
initializeOptimisticLockingprotected void initializeOptimisticLocking()INTERNAL: Potentially override the optimistic locking behavior
- 
initializeCacheInvalidationPolicyprotected void initializeCacheInvalidationPolicy()INTERNAL: Potentially override the cache invalidation behavior
- 
initializeWithAllSubclassesExpressionINTERNAL: Initialize the expression to use for queries to the class and its subclasses.- Throws:
- DescriptorException
 
- 
isChildDescriptorpublic boolean isChildDescriptor()INTERNAL: Check if it is a child descriptor.
- 
isJoinedStrategypublic boolean isJoinedStrategy()INTERNAL: Indicate whether a single table or joined inheritance strategy is being used. Since we currently do not support TABLE_PER_CLASS, indicating either joined/not joined is sufficient.- Returns:
- isJoinedStrategy value
 
- 
isRootParentDescriptorpublic boolean isRootParentDescriptor()INTERNAL: Return whether or not is root parent descriptor- Specified by:
- isRootParentDescriptorin class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
postInitializepublic void postInitialize(org.eclipse.persistence.internal.sessions.AbstractSession session) INTERNAL: Initialized the inheritance properties that cannot be initialized until after the mappings have been.
- 
preInitializepublic void preInitialize(org.eclipse.persistence.internal.sessions.AbstractSession session) throws DescriptorException INTERNAL: Allow the inheritance properties of the descriptor to be initialized. The descriptor's parent must first be initialized.- Throws:
- DescriptorException
 
- 
readSubclassesOnQueriespublic void readSubclassesOnQueries()PUBLIC: Set the descriptor to read instance of itself and its subclasses when queried. This is used with inheritance to configure the result of queries. By default this is true for root inheritance descriptors, and false for all others.
- 
remoteInitializationINTERNAL: Used to initialize a remote descriptor.
- 
requiresMultipleTableSubclassReadpublic boolean requiresMultipleTableSubclassRead()INTERNAL: Return if this descriptor has children that define additional tables and needs to read them. This case requires a special read, because the query cannot be done through a single SQL call with normal joins.
- 
selectAllRowUsingCustomMultipleTableSubclassReadprotected Vector selectAllRowUsingCustomMultipleTableSubclassRead(ObjectLevelReadQuery query) throws DatabaseException INTERNAL: Select all rows from a abstract table descriptor. This is accomplished by selecting for all of the concrete classes and then merging the rows. This does not optimize using type select, as the type information is not known.- Returns:
- vector containing database rows.
- Throws:
- DatabaseException- - an error has occurred on the database.
 
- 
selectAllRowUsingDefaultMultipleTableSubclassReadprotected Vector selectAllRowUsingDefaultMultipleTableSubclassRead(ObjectLevelReadQuery query) throws DatabaseException, QueryException INTERNAL: Select all rows from a abstract table descriptor. This is accomplished by selecting for all of the concrete classes and then merging the rows.- Returns:
- vector containing database rows.
- Throws:
- DatabaseException- - an error has occurred on the database.
- QueryException
 
- 
removeChildrenprotected void removeChildren(ClassDescriptor descriptor, Set<Class> classes, Set<Class> subclasses) Remove all of the subclasses (and so on) from the set of classes.
- 
selectAllRowUsingMultipleTableSubclassReadpublic Vector selectAllRowUsingMultipleTableSubclassRead(ObjectLevelReadQuery query) throws DatabaseException INTERNAL: Select all rows from a abstract table descriptor. This is accomplished by selecting for all of the concrete classes and then merging the rows.- Returns:
- vector containing database rows.
- Throws:
- DatabaseException- - an error has occurred on the database.
 
- 
selectOneRowUsingCustomMultipleTableSubclassReadprotected org.eclipse.persistence.internal.sessions.AbstractRecord selectOneRowUsingCustomMultipleTableSubclassRead(ReadObjectQuery query) throws DatabaseException INTERNAL: Select one rows from a abstract table descriptor. This is accomplished by selecting for all of the concrete classes until a row is found. This does not optimize using type select, as the type information is not known.- Throws:
- DatabaseException- - an error has occurred on the database.
 
- 
selectOneRowUsingDefaultMultipleTableSubclassReadprotected org.eclipse.persistence.internal.sessions.AbstractRecord selectOneRowUsingDefaultMultipleTableSubclassRead(ReadObjectQuery query) throws DatabaseException, QueryException INTERNAL: Select one row of any concrete subclass, This must use two selects, the first retrieves the type field only.- Throws:
- DatabaseException
- QueryException
 
- 
selectOneRowUsingMultipleTableSubclassReadpublic org.eclipse.persistence.internal.sessions.AbstractRecord selectOneRowUsingMultipleTableSubclassRead(ReadObjectQuery query) throws DatabaseException, QueryException INTERNAL: Select one row of any concrete subclass, This must use two selects, the first retrieves the type field only.- Throws:
- DatabaseException
- QueryException
 
- 
setAllChildClassIndicatorsINTERNAL:
- 
setChildDescriptorsINTERNAL:
- 
setClassExtractionMethodNameADVANCED: A class extraction method can be registered with the descriptor to override the default inheritance mechanism. This allows for a user defined class indicator in place of providing an explicit class indicator field. The method registered must be a static method on the class which has that descriptor. The method must take Record as an argument (for example, a DatabaseRecord), and must return the class to use for that record. 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 record. If this method is used then the class indicator field and mapping cannot be used, and in addition, the descriptor's withAllSubclasses and onlyInstances expressions must also be set up correctly.
- 
setClassIndicatorAssociationsINTERNAL: Set the class indicator associations from reading the deployment XML.
- 
setClassIndicatorFieldpublic void setClassIndicatorField(org.eclipse.persistence.internal.helper.DatabaseField classIndicatorField) ADVANCED: To set the class indicator field. This can be used for advanced field types, such as XML nodes, or to set the field type.- Specified by:
- setClassIndicatorFieldin class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
setClassIndicatorFieldNamePUBLIC: To set the class indicator field name. This is the name of the field in the table that stores what type of object this is.
- 
setClassIndicatorMappingPUBLIC: Set the association of indicators and classes. This may be desired to be used by clients in strange inheritance models.- Specified by:
- setClassIndicatorMappingin class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
setClassNameIndicatorMappingINTERNAL: Set the class name indicator mapping, used by the MW.
- 
setDescriptorINTERNAL: Set the descriptor.- Specified by:
- setDescriptorin class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
setDescribesNonPersistentSubclassespublic void setDescribesNonPersistentSubclasses(boolean describesNonPersistentSubclasses) ADVANCED: Determines whether the descriptors using this inheritance policy should be used as descriptors for subclasses of the classes they describe if those subclasses do not have their own descriptor e.g. If Employee.class has a descriptor and EmployeeSubClass does not have a descriptor, if describesNonPersistenceSubclasses is true Employee's descriptor will be used as the descriptor for Employee- Parameters:
- describesNonPersistentSubclasses-
 
- 
setJoinedStrategypublic void setJoinedStrategy()INTERNAL: Used to indicate a JOINED inheritance strategy.
- 
setOnlyInstancesExpressionADVANCED: Sets the expression used to select instance of the class only. Can be used to customize the inheritance class indicator expression.
- 
setParentClassPUBLIC: Set the parent class. A descriptor can inherit from another descriptor through defining it as its parent. The root descriptor must define a class indicator field and mapping. All children must share the same table as their parent but can add additional tables. All children must share the root descriptor primary key.
- 
setParentClassNameINTERNAL: Set the parent class name, used by MW to avoid referencing the real class for deployment XML generation.- Specified by:
- setParentClassNamein class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
setParentDescriptorINTERNAL:
- 
setReadAllSubclassesViewprotected void setReadAllSubclassesView(org.eclipse.persistence.internal.helper.DatabaseTable readAllSubclassesView) INTERNAL: The view can be used to optimize/customize the query for all subclasses where they have multiple tables. This view can do the outer join, we require the view because we cannot generate dynamic platform independent SQL for outer joins (i.e. not possible to do so either).
- 
setReadAllSubclassesViewNameADVANCED: The view can be used to optimize/customize the query for all subclasses where they have multiple tables. This view can use outer joins or unions to combine the results of selecting from all of the subclass tables. If a view is not given then TopLink must make an individual call for each subclass.
- 
setShouldReadSubclassesINTERNAL: Set the descriptor to read instance of itself and its subclasses when queried. This is used with inheritance to configure the result of queries. By default this is true for root inheritance descriptors, and false for all others.- Specified by:
- setShouldReadSubclassesin class- CoreInheritancePolicy<org.eclipse.persistence.internal.sessions.AbstractRecord,- org.eclipse.persistence.internal.sessions.AbstractSession, - ClassDescriptor, - org.eclipse.persistence.internal.helper.DatabaseField> 
 
- 
setShouldReadSubclassespublic void setShouldReadSubclasses(boolean shouldReadSubclasses) PUBLIC: Set the descriptor to read instance of itself and its subclasses when queried. This is used with inheritance to configure the result of queries. By default this is true for root inheritance descriptors, and false for all others.
- 
setShouldUseClassNameAsIndicatorpublic void setShouldUseClassNameAsIndicator(boolean shouldUseClassNameAsIndicator) PUBLIC: Set if the descriptor uses the classes fully qualified name as the indicator. The class indicator is used with inheritance to determine the class from a row. By default a class indicator mapping is required, this can be set to true if usage of the class name is desired. The field must be of a large enough size to store the fully qualified class name.
- 
setAlwaysUseOuterJoinForClassTypepublic void setAlwaysUseOuterJoinForClassType(boolean choice) PUBLIC: Sets the inheritance policy to always use an outer join when querying across a relationship of class. used when using getAllowingNull(), or anyOfAllowingNone()
- 
setSingleTableStrategypublic void setSingleTableStrategy()INTERNAL: Used to indicate a SINGLE_TABLE inheritance strategy. Since only JOINED and SINGLE_TABLE strategies are supported at this time (no support for TABLE_PER_CLASS) using a !isJoinedStrategy an an indicator for SINGLE_TABLE is sufficient.
- 
setUseDescriptorsToValidateInheritedObjectspublic void setUseDescriptorsToValidateInheritedObjects(boolean useDescriptorsToValidateInheritedObjects) INTERNAL: Sets if we should use the descriptor inheritance to determine if an object can be returned from the identity map or not.
- 
setWithAllSubclassesExpressionADVANCED: Sets the expression to be used for querying for a class and all its subclasses. Can be used to customize the inheritance class indicator expression.
- 
shouldReadSubclassespublic boolean shouldReadSubclasses()PUBLIC: Return true if this descriptor should read instances of itself and subclasses on queries.
- 
shouldReadSubclassesValueINTERNAL: Return true if this descriptor should read instances of itself and subclasses on queries.
- 
shouldAlwaysUseOuterJoinpublic boolean shouldAlwaysUseOuterJoin()PUBLIC: returns if the inheritance policy will always use an outerjoin when selecting class type
- 
shouldOuterJoinSubclassespublic boolean shouldOuterJoinSubclasses()PUBLIC: Return if an outer join should be used to read subclasses. By default a separate query is done for each subclass when querying for a root or branch inheritance class that has subclasses that span multiple tables.
- 
setShouldOuterJoinSubclassespublic void setShouldOuterJoinSubclasses(boolean shouldOuterJoinSubclasses) PUBLIC: Set if an outer join should be used to read subclasses. By default a separate query is done for each subclass when querying for a root or branch inheritance class that has subclasses that span multiple tables.
- 
shouldUseClassNameAsIndicatorpublic boolean shouldUseClassNameAsIndicator()PUBLIC: Return true if the descriptor use the classes full name as the indicator. The class indicator is used with inheritance to determine the class from a row. By default a class indicator mapping is required, this can be set to true if usage of the class name is desired. The field must be of a large enough size to store the fully qualified class name.
- 
toStringINTERNAL:
- 
updateTablesprotected void updateTables()INTERNAL: set the tables on the child descriptor overridden in org.eclipse.persistence.internal.oxm.QNameInheritancePolicy
- 
useClassNameAsIndicatorpublic void useClassNameAsIndicator()PUBLIC: Set the descriptor to use the classes full name as the indicator. The class indicator is used with inheritance to determine the class from a row. By default a class indicator mapping is required, this can be set to true if usage of the class name is desired. The field must be of a large enough size to store the fully qualified class name.
 
-