| Oracle Application Server TopLink Mapping Workbench User's Guide 10g (9.0.4) Part Number B10316-01 | 
 | 
Relational mappings define how persistent objects reference other persistent objects. Oracle Application Server TopLink supports the following object relational mapping types:
These mappings allow for an object model to be persisted into an object-relational data-model. Currently the OracleAS TopLink Mapping Workbench does not support object-relational mappings--they must be defined in code or through amendment methods. See "Working with Object-relational Descriptors" for more information.
Object-relational mappings allow for an object model to be persisted into an object-relational data-model. The OracleAS TopLink Mapping Workbench does not directly support these mappings--you must define them in code through amendment methods.
OracleAS TopLink supports the following object-relational mappings:
In an object-relational data-model, structures can contain arrays (collections of other data types). These arrays can contain primitive data types or collections of other structures. OracleAS TopLink stores the arrays with their parent structure in the same table.
All elements in the array must be the same data type. The number of elements in an array controls the size of the array. An Oracle database allows arrays of variable sizes (called Varrays).
Oracle8i offers two collection types:
OracleAS TopLink supports arrays of primitive data through the ArrayMapping class. This is similar to DirectCollectionMapping - it represents a collection of primitives in Java. However, the ArrayMapping class does not require an additional table to store the values in the collection.
OracleAS TopLink supports arrays of aggregate structures through the ObjectArrayMaping class.
OracleAS TopLink supports nested tables through the NestedTableMapping class.
Array mappings are instances of the ArrayMapping class. You must associate this mapping to an attribute in the parent class. OracleAS TopLink requires the following elements for an array mapping:
setAttributeName( ) message.
setFieldName( ) message.
setStructureName( ) message.
Table 7-1 summarizes all array mapping properties:
The following code example illustrates creating an array mapping for the Employee source class and registering it with the descriptor 
// Create a new mapping and register it with the source descriptor. ArrayMapping arrayMapping = new ArrayMapping(); arrayMapping.setAttributeName("responsibilities"); arrayMapping.setStructureName("Responsibilities_t"); arrayMapping.setFieldName("RESPONSIBILITIES"); descriptor.addMapping(arrayMapping);
The following table summarizes all array mapping properties. In the Method Names column, arguments are bold, methods are not.
In an object-relational data-model, object arrays allow for an array of object types or structures to be embedded into a single column in a database table or an object table. OracleAS TopLink supports object array mappings to define a collection-aggregated relationship in which the target objects share the same row as the source object.
Object array mappings are instances of the ObjectArrayMapping class. You must associate this mapping to an attribute in the parent class. OracleAS TopLink requires the following elements for an object array mapping:
setAttributeName( ) message.
setFieldName( ) message.
setStructureName( ) message.
Use the optional setGetMethodName( ) and setSetMethodName( ) messages to access the attribute through user-defined methods rather than directly. See "Specifying Direct Access and Method Access" for more information. Table 7-2 summarizes all object array mapping properties.
The following code example illustrates creating an object array mapping for the Insurance source class and registering it with the descriptor.
// Create a new mapping and register it with the source descriptor. ObjectArrayMapping phonesMapping = new ObjectArrayMapping(); phonesMapping.setAttributeName("phones"); phonesMapping.setGetMethodName("getPhones"); phonesMapping.setSetMethodName("setPhones"); phonesMapping.setStructureName("PHONELIST_TYPE"); phonesMapping.setReferenceClass(Phone.class); phonesMapping.setFieldName("PHONES"); descriptor.addMapping(phonesMapping);
The following table summarizes all object array mapping properties. In the Method Names column, arguments are bold, methods are not.
In an object-relational data-model, structures are user defined data-types or object-types. This is similar to a Java class--it defines attributes or fields in which each attribute is either:
OracleAS TopLink maps each structure to a Java class defined in your object model and defines a descriptor for each class. A StructureMapping class maps nested structures, similar to an AggregateObjectMapping class. However, the structure mapping supports null values and shared aggregates without requiring additional settings (because of the object-relational support of the database).
Structure mappings are instances of the StructureMapping class. You must associate this mapping to an attribute in each of the parent classes. OracleAS TopLink requires the following elements for structure mapping:
setAttributeName( ) message.
setFieldName( ) message.
setReferenceClass( ) message.
Use the optional setGetMethodName( ) and setSetMethodName( ) messages to access the attribute through user-defined methods, rather than directly. See "Specifying Direct Access and Method Access" for more information.
You must make the following changes to the target (child) class descriptor:
descriptorIsAggregate() message to indicate it is not a root level.
Table 7-3 summarizes all structure mapping properties:
The following code example illustrates creating a structure mapping for the Employee source class and registering it with the descriptor 
// Create a new mapping and register it with the source descriptor. StructureMapping structureMapping = new StructureMapping(); structureMapping.setAttributeName("address"); structureMapping.setReferenceClass(Address.class); structureMapping.setFieldName("address"); descriptor.addMapping(structureMapping);
The following code example illustrates creating the descriptor of the Address aggregate target class. The aggregate target descriptor does not need a mapping to its parent, or any table or primary key information.
// Create a descriptor for the aggregate class. The table name and primary key are not specified in the aggregate descriptor. ObjectRelationalDescriptor descriptor = new ObjectRelationalDescriptor (); descriptor.setJavaClass(Address.class); descriptor.setStructureName("ADDRESS_T"); descriptor.descriptorIsAggregate(); // Define the field ordering descriptor.addFieldOrdering("STREET"); descriptor.addFieldOrdering("CITY"); ... // Define the attribute mappings or relationship mappings. ...
The following table summarizes all structure mapping properties. In the Method Names column, arguments are bold, methods are not.
In an object-relational data-model, structures reference each other through refs--not through foreign keys (as in a traditional data-model). Refs are based on the target structure's ObjectID.
OracleAS TopLink supports refs through the ReferenceMapping class. They represent an object reference in Java, similar to a OneToOneMapping. However, the reference mapping does not require foreign key information.
Reference mappings are instances of the ReferenceMapping class. You must associate this mapping to an attribute in the source class. OracleAS TopLink requires the following elements for a reference mapping:
setAttributeName( ) message.
setFieldName( ) message.
setReferenceClass( ) message.
Use the optional setGetMethodName( ) and setSetMethodName( ) messages to access the attribute through user-defined methods rather than directly. See "Specifying Direct Access and Method Access" for more information.
Table 7-4 summarizes all reference mapping properties.
The following code example illustrates creating a reference mapping for the Employee source class and registering it with the descriptor.
// Create a new mapping and register it with the source descriptor. ReferenceMapping refrenceMapping = new ReferenceMapping(); referenceMapping.setAttributeName("manager"); referenceMapping.setReferenceClass(Employee.class); referenceMapping.setFieldName("MANAGER"); descriptor.addMapping(refrenceMapping);
The following table summarizes all reference mapping properties. In the Method Names column, arguments are bold, methods are not.
Nested table types model an unordered set of elements. These elements may be built-in or user-defined types. You can view a nested table as a single-column table or, if the nested table is an object type, as a muticolumn table (with a column for each attribute of the object type).
Typically, nested tables represent a one-to-many or many-to-many relationship of references to another independent structure. They support querying and joining better than Varrays that are inlined to the parent table.
OracleAS TopLink supports nested table through the NestedTableMapping class. They represent a collection of object references in Java, similar to a OneToManyMapping or ManyToManyMapping. However, the nested table mapping does not require foreign key information (as with a one-to-many mapping) or the relational table (as with a many-to-many mapping).
Nested table mappings are instances of the NestedTableMapping class. This mapping is associated to an attribute in the parent class. The following elements are required for a nested table mapping to be viable:
setAttributeName() message
 setFieldName() message
setStructureName() message
Use the optional setGetMethodName() and setSetMethodName() messages to allow OracleAS TopLink to access the attribute through user-defined methods, rather than directly. See "Specifying Direct Access and Method Access" for more information.
Table 7-5 summarizes all nested table mapping properties.
The following code example illustrates creating a nested table mapping for the Insurance source class and registering it with the descriptor.
// Create a new mapping and register it with the source descriptor. NestedTableMapping policiesMapping = new NestedTableMapping(); policiesMapping.setAttributeName("policies"); policiesMapping.setGetMethodName("getPolicies"); policiesMapping.setSetMethodName("setPolicies"); policiesMapping.setReferenceClass(Policy.class); policiesMapping.dontUseIndirection(); policiesMapping.setStructureName("POLICIES_TYPE"); policiesMapping.setFieldName("POLICIES"); policiesMapping.privateOwnedRelationship(); policiesMapping.setSelectionSQLString("select p.* from policyHolders ph, table(ph.policies) t, policies p where ph.ssn=#SSN and ref(p) = value(t)"); descriptor.addMapping(policiesMapping);
The following table summarizes all nested table mapping properties. In the Method Names column, arguments are bold, methods are not.
| 
 |  Copyright © 1997, 2003 Oracle Corporation. All Rights Reserved. | 
 |