Oracle TopLink Developer's Guide
10g Release 3 (10.1.3) B13593-01 |
|
![]() Previous |
![]() Next |
Inheritance describes how a derived (child) class inherits the characteristics of its superclass (parent). When you designate a class as a parent, you can configure how TopLink handles the class's inheritance hierarchy.
Table 28-23 summarizes which descriptors support parent inheritance configuration.
Table 28-21 Descriptor Support for Parent Inheritance Configuration
Descriptor | Using TopLink Workbench | Using Java
|
---|---|---|
Relational Descriptors |
|
|
Object-Relational Descriptors |
![]() |
|
EIS Descriptors |
|
|
XML Descriptors |
|
|
For more information about configuring inheritance for a child (branch or leaf) class descriptor, see "Configuring Inheritance for a Child (Branch or Leaf) Class Descriptor".
For more information, see "Descriptors and Inheritance".
To create a root class for an inheritance, use this procedure.
In the Navigator, select the descriptor you wish to specify as the root.
Choose the Inheritance tab in the Property window.
If the Inheritance tab is not visible, right-click the descriptor and choose Select Advanced Properties > Inheritance.
Select the Is Root Parent Descriptor option to specify this descriptor is a root class.
Use this table to complete the following root descriptor field on the Inheritance tab:
Field | Description |
---|---|
Is Root Parent Descriptor | Select this option to specify this descriptor as the root (parent) of the inheritance hierarchy. |
Use Class Extraction Method | Choose this option to specify a class indicator using a class extraction method, and select your static class extraction method from the list.
For more information, see "Using Class Extraction Methods". |
Use Class Indicator Field | Choose this option to specify a class indicator using a class indicator field.
For more information, see "Using Class Indicator Fields". |
Field Selection | Choose the field to use as the class indicator field. |
Use XML Schema "Type" AttributeFoot 1 | Select this option to use the type attribute specified in the XML schema for this descriptor's reference class. |
Specify Field | For a relational descriptor, select the field of the database table associated with this descriptor (see "Configuring Associated Tables").
For an EIS root descriptor (using XML records) or an XML descriptor, click Browse to select an element attribute or text node. |
Indicator Selection | Choose between using a class name as the class indicator field value or specifying specific class indicator field values for each (nonabstract) child class. |
Use Class Name as Indicator | Choose this option to use class names as the class indicator field value. |
Use Class Indicator Dictionary | Choose this option to specify specific class indicator field values for each (nonabstract) child class.
When you choose this option, you must specify the data type of the class indicator field and the specific class indicator field values for each (nonabstract) child class. |
Indicator Type | Select the data type from the list to specify the data type of the class indicator field.
To specify the specific class indicator field values for each (nonabstract) child class, click Edit and enter the appropriate value for each child class. |
Footnote 1 EIS root (see "EIS Root Descriptors") or XML descriptors (see "XML Descriptors") only.
Create a descriptor amendment method ("Configuring Amendment Methods") to customize the root class descriptor's InheritancePolicy
using InheritancePolicy
methods setParentClass
, setClassIndicatorFieldName
, addClassIndicator
, useClassNameAsIndicator
and setClassExtractionMethodName
, as required.
Example 28-13 shows amendment methods for the Person
and Student
classes where Student
extends Person
in a relational project. In this example, a class indicator field is used (see "Using Class Indicator Fields").
Example 28-11 Configuring Inheritance for a Relational Root Class
... public static void addToPersonDescriptor(Descriptor descriptor) { descriptor.getInheritancePolicy().setClassIndicatorFieldName("CLIENT_TYPE"); descriptor.getInheritancePolicy().addClassIndicator("P"); } public static void addToStudentDescriptor(Descriptor descriptor) { descriptor.getInheritancePolicy().setParentClass(Person.class); descriptor.getInheritancePolicy().setClassIndicatorFieldName("CLIENT_TYPE"); descriptor.getInheritancePolicy().addClassIndicator("S"); } ...
If you are using a class-extraction method (see "Using Class Extraction Methods"), you may also need to use InheritancePolicy
methods setOnlyInstancesExpression
and setWithAllSubclassesExpression
(see "Configuring Inheritance Expressions for a Parent (Root) Class Descriptor").
Example 28-13 shows amendment methods for the Person
and Student
classes where Student
extends Person
in an EIS project using XML records. In this example, a class indicator field is used (see "Using Class Indicator Fields").
Example 28-12 Configuring Inheritance for an EIS Root Class
... public static void addToPersonDescriptor(Descriptor descriptor) { descriptor.getInheritancePolicy().setClassIndicatorField( new XMLField("@CLIENT_TYPE") ); descriptor.getInheritancePolicy().addClassIndicator("P"); } public static void addToStudentDescriptor(Descriptor descriptor) { descriptor.getInheritancePolicy().setParentClass(Person.class); descriptor.getInheritancePolicy().setClassIndicatorField( new XMLField("@CLIENT_TYPE") ); descriptor.getInheritancePolicy().addClassIndicator("S"); } ...