Class AbstractCompositeDirectCollectionMapping

All Implemented Interfaces:
Serializable, Cloneable, ContainerMapping, ArrayCollectionMapping
Direct Known Subclasses:
ArrayMapping, EISCompositeDirectCollectionMapping, XMLCompositeDirectCollectionMapping, XMLFragmentCollectionMapping

public abstract class AbstractCompositeDirectCollectionMapping extends DatabaseMapping implements ContainerMapping, ArrayCollectionMapping
AbstractCompositeDirectCollectionMapping consolidates the behavior of mappings that map collections of "native" data objects (e.g. Strings). These are objects that do not have their own descriptor and repeat within the XML record for the containing object.
Since:
TOPLink/Java 3.0
See Also:
  • Field Details

    • field

      protected DatabaseField field
      This is the field holding the nested collection.
    • elementDataTypeName

      protected String elementDataTypeName
      This is the "data type" associated with each element in the nested collection. Depending on the data store, this could be optional.
    • valueConverter

      protected Converter valueConverter
      Allows user defined conversion between the object value and the database value.
  • Constructor Details

    • AbstractCompositeDirectCollectionMapping

      protected AbstractCompositeDirectCollectionMapping()
      Default constructor.
  • Method Details

    • getValueConverter

      public Converter getValueConverter()
      PUBLIC: Return the converter on the mapping. A converter can be used to convert between the direct collection's object value and database value.
    • hasValueConverter

      public boolean hasValueConverter()
      PUBLIC: Indicates if there is a converter on the mapping.
    • setValueConverter

      public void setValueConverter(Converter valueConverter)
      PUBLIC: Set the converter on the mapping. A converter can be used to convert between the direct collection's object value and database value.
    • buildAddedElementFromChangeSet

      public Object buildAddedElementFromChangeSet(Object changeSet, MergeManager mergeManager, AbstractSession targetSession)
      INTERNAL: Build and return a new element based on the change set.
      Specified by:
      buildAddedElementFromChangeSet in interface ArrayCollectionMapping
    • buildBackupClone

      public void buildBackupClone(Object clone, Object backup, UnitOfWorkImpl unitOfWork)
      INTERNAL: Clone the attribute from the clone and assign it to the backup. For these mappings, this is the same as building the first clone.
      Specified by:
      buildBackupClone in class DatabaseMapping
      Parameters:
      clone - TODO
      backup - TODO
      unitOfWork - TODO
    • buildChangeSet

      public Object buildChangeSet(Object element, ObjectChangeSet owner, AbstractSession session)
      INTERNAL: Build and return a change set for the specified element. Direct collections simply store the element itself, since it is immutable.
      Specified by:
      buildChangeSet in interface ArrayCollectionMapping
    • buildClone

      public void buildClone(Object original, CacheKey cacheKey, Object clone, Integer refreshCascade, AbstractSession cloningSession)
      INTERNAL: Clone the attribute from the original and assign it to the clone.
      Specified by:
      buildClone in class DatabaseMapping
      Parameters:
      original - TODO
      cacheKey - TODO
      clone - TODO
      refreshCascade - TODO
      cloningSession - TODO
    • buildCloneFromRow

      public void buildCloneFromRow(AbstractRecord row, JoinedAttributeManager joinManager, Object clone, CacheKey sharedCacheKey, ObjectBuildingQuery sourceQuery, UnitOfWorkImpl unitOfWork, AbstractSession executionSession)
      INTERNAL: Extract value from the row and set the attribute to this value in the working copy clone. In order to bypass the shared cache when in transaction a UnitOfWork must be able to populate working copies directly from the row.
      Specified by:
      buildCloneFromRow in class DatabaseMapping
      Parameters:
      row - TODO
      joinManager - TODO
      clone - TODO
      sharedCacheKey - TODO
      sourceQuery - TODO
      unitOfWork - TODO
      executionSession - TODO
    • buildClonePart

      protected Object buildClonePart(Object attributeValue, CacheKey parentCacheKey, AbstractSession cloningSession)
      Build and return a clone of the specified attribute value.
    • buildCopy

      public void buildCopy(Object copy, Object original, CopyGroup group)
      INTERNAL: Copy of the attribute of the object. This is NOT used for unit of work but for templatizing an object.
      Overrides:
      buildCopy in class DatabaseMapping
      Parameters:
      copy - TODO
      original - TODO
      group - TODO
    • buildElementFromChangeSet

      protected Object buildElementFromChangeSet(Object changeSet, MergeManager mergeManager, AbstractSession targetSession)
      Build and return a new element based on the change set. Direct collections simply store the element itself, since it is immutable.
    • buildElementFromElement

      public Object buildElementFromElement(Object object, MergeManager mergeManager, AbstractSession targetSession)
      INTERNAL: Build and return a new element based on the specified element. Direct collections simply return the element itself, since it is immutable.
      Specified by:
      buildElementFromElement in interface ArrayCollectionMapping
    • buildRemovedElementFromChangeSet

      public Object buildRemovedElementFromChangeSet(Object changeSet, MergeManager mergeManager, AbstractSession targetSession)
      INTERNAL: Build and return a new element based on the change set.
      Specified by:
      buildRemovedElementFromChangeSet in interface ArrayCollectionMapping
    • cascadePerformRemoveIfRequired

      public void cascadePerformRemoveIfRequired(Object object, UnitOfWorkImpl uow, Map visitedObjects)
      INTERNAL: Cascade perform delete through mappings that require the cascade
      Specified by:
      cascadePerformRemoveIfRequired in class DatabaseMapping
      Parameters:
      object - TODO
      uow - TODO
      visitedObjects - TODO
    • cascadeRegisterNewIfRequired

      public void cascadeRegisterNewIfRequired(Object object, UnitOfWorkImpl uow, Map visitedObjects)
      INTERNAL: Cascade registerNew for Create through mappings that require the cascade
      Specified by:
      cascadeRegisterNewIfRequired in class DatabaseMapping
      Parameters:
      object - TODO
      uow - TODO
      visitedObjects - TODO
    • collectFields

      protected Vector collectFields()
      Return the fields handled by the mapping.
      Overrides:
      collectFields in class DatabaseMapping
      Returns:
      TODO
    • compareElements

      public boolean compareElements(Object element1, Object element2, AbstractSession session)
      INTERNAL: Compare the non-null elements. Return true if they are alike. Use #equals() to determine if two elements are the same.
      Specified by:
      compareElements in interface ArrayCollectionMapping
    • compareElementsForChange

      public boolean compareElementsForChange(Object element1, Object element2, AbstractSession session)
      INTERNAL: Compare the non-null elements and return true if they are alike.
      Specified by:
      compareElementsForChange in interface ArrayCollectionMapping
    • convertToChangeRecord

      protected ChangeRecord convertToChangeRecord(Object cloneCollection, ObjectChangeSet owner, AbstractSession session)
    • fixObjectReferences

      public void fixObjectReferences(Object object, Map<Object,ObjectDescriptor> objectDescriptors, Map<Object,Object> processedObjects, ObjectLevelReadQuery query, DistributedSession session)
      INTERNAL: An object has been serialized from the server to the client. Replace the transient attributes of the remote value holders with client-side objects.
      Specified by:
      fixObjectReferences in class DatabaseMapping
      Parameters:
      object - TODO
      objectDescriptors - TODO
      processedObjects - TODO
      query - TODO
      session - TODO
    • getAttributeElementClass

      public Class<?> getAttributeElementClass()
      PUBLIC: Return the class each element in the object's collection should be converted to, before the collection is inserted into the object. This is optional - if left null, the elements will be added to the object's collection unconverted.
    • getContainerPolicy

      public ContainerPolicy getContainerPolicy()
      INTERNAL: Return the mapping's containerPolicy.
      Specified by:
      getContainerPolicy in interface ContainerMapping
      Overrides:
      getContainerPolicy in class DatabaseMapping
      Returns:
      TODO
    • getField

      public DatabaseField getField()
      INTERNAL: Return the field that holds the nested collection.
      Overrides:
      getField in class DatabaseMapping
      Returns:
      TODO
    • isAbstractCompositeDirectCollectionMapping

      public boolean isAbstractCompositeDirectCollectionMapping()
      INTERNAL:
      Overrides:
      isAbstractCompositeDirectCollectionMapping in class DatabaseMapping
      Returns:
      TODO
    • getFieldElementClass

      public Class<?> getFieldElementClass()
      PUBLIC: Return the class each element in the database row's collection should be converted to, before the collection is inserted into the database. This is optional - if left null, the elements will be added to the database row's collection unconverted.
    • getFieldName

      public String getFieldName()
      PUBLIC: Return the name of the field that holds the nested collection.
    • getRealCollectionAttributeValueFromObject

      public Object getRealCollectionAttributeValueFromObject(Object object, AbstractSession session) throws DescriptorException
      INTERNAL: Convenience method. Return the value of an attribute, unwrapping value holders if necessary. If the value is null, build a new container.
      Specified by:
      getRealCollectionAttributeValueFromObject in interface ArrayCollectionMapping
      Overrides:
      getRealCollectionAttributeValueFromObject in class DatabaseMapping
      Throws:
      DescriptorException
    • initialize

      public void initialize(AbstractSession session) throws DescriptorException
      INTERNAL: Initialize the mapping.
      Overrides:
      initialize in class DatabaseMapping
      Throws:
      DescriptorException
    • iterate

      public void iterate(DescriptorIterator iterator)
      INTERNAL: Iterate on the appropriate attribute value.
      Specified by:
      iterate in class DatabaseMapping
    • mapKeyHasChanged

      public boolean mapKeyHasChanged(Object element, AbstractSession session)
      INTERNAL: Return whether the element's user-defined Map key has changed since it was cloned from the original version. Direct elements are not allowed to have keys.
      Specified by:
      mapKeyHasChanged in interface ArrayCollectionMapping
    • setAttributeElementClass

      public void setAttributeElementClass(Class<?> attributeElementClass)
      PUBLIC: Set the class each element in the object's collection should be converted to, before the collection is inserted into the object. This is optional - if left null, the elements will be added to the object's collection unconverted.
    • setAttributeElementClassName

      public void setAttributeElementClassName(String attributeElementClass)
      PUBLIC: Set the class each element in the object's collection should be converted to, before the collection is inserted into the object. This is optional - if left null, the elements will be added to the object's collection unconverted.
    • setContainerPolicy

      public void setContainerPolicy(ContainerPolicy containerPolicy)
      ADVANCED: Set the mapping's containerPolicy.
      Specified by:
      setContainerPolicy in interface ContainerMapping
    • setField

      public void setField(DatabaseField field)
      Set the field that holds the nested collection.
    • setFieldElementClass

      public void setFieldElementClass(Class<?> fieldElementClass)
      PUBLIC: Set the class each element in the database row's collection should be converted to, before the collection is inserted into the database. This is optional - if left null, the elements will be added to the database row's collection unconverted.
    • useCollectionClass

      public void useCollectionClass(Class<?> concreteClass)
      PUBLIC: Configure the mapping to use an instance of the specified container class to hold the nested objects.

      jdk1.2.x: The container class must implement (directly or indirectly) the Collection interface.

      jdk1.1.x: The container class must be a subclass of Vector.

      Specified by:
      useCollectionClass in interface ContainerMapping
    • useCollectionClassName

      public void useCollectionClassName(String concreteClassName)
      INTERNAL: Used to set the collection class by name. This is required when building from metadata to allow the correct class loader to be used.
      Specified by:
      useCollectionClassName in interface ContainerMapping
    • useListClassName

      public void useListClassName(String concreteClassName)
      INTERNAL: Used to set the collection class by name. This is required when building from metadata to allow the correct class loader to be used.
      Specified by:
      useListClassName in interface ContainerMapping
    • useMapClass

      public void useMapClass(Class<?> concreteClass, String methodName)
      PUBLIC: Mapping does not support Map containers. It supports only Collection containers.
      Specified by:
      useMapClass in interface ContainerMapping
    • useMapClassName

      public void useMapClassName(String concreteContainerClassName, String methodName)
      Description copied from interface: ContainerMapping
      PUBLIC: Configure the mapping to use an instance of the specified container class to hold the target objects. The key used to index a value in the Map is the value returned by a call to the specified zero-argument method. The method must be implemented by the class (or a superclass) of any value to be inserted into the Map.

      The container class must implement (directly or indirectly) the java.util.Map interface.

      To facilitate resolving the method, the mapping's referenceClass must set before calling this method.

      Specified by:
      useMapClassName in interface ContainerMapping
    • setUsesSingleNode

      public void setUsesSingleNode(boolean usesSingleNode)
      PUBLIC: Sets whether the mapping uses a single node.
      Parameters:
      usesSingleNode - true if the items in the collection are in a single node or false if each of the items in the collection is in its own node
    • usesSingleNode

      public boolean usesSingleNode()
      PUBLIC: Checks whether the mapping uses a single node.
      Returns:
      True if the items in the collection are in a single node or false if each of the items in the collection is in its own node.
    • valueFromRow

      public Object valueFromRow(AbstractRecord row, JoinedAttributeManager joinManager, ObjectBuildingQuery sourceQuery, CacheKey cacheKey, AbstractSession executionSession, boolean isTargetProtected, Boolean[] wasCacheUsed) throws DatabaseException
      INTERNAL: Build the nested collection from the database row.
      Overrides:
      valueFromRow in class DatabaseMapping
      Throws:
      DatabaseException
    • writeFromObjectIntoRow

      public void writeFromObjectIntoRow(Object object, AbstractRecord row, AbstractSession session, DatabaseMapping.WriteType writeType)
      INTERNAL: Get the attribute value from the object and store it in the appropriate field of the row.
      Overrides:
      writeFromObjectIntoRow in class DatabaseMapping
    • writeFromObjectIntoRowForUpdate

      public void writeFromObjectIntoRowForUpdate(WriteObjectQuery writeQuery, AbstractRecord row) throws DescriptorException
      INTERNAL: If any part of the nested collection has changed, the whole thing is written.
      Overrides:
      writeFromObjectIntoRowForUpdate in class DatabaseMapping
      Throws:
      DescriptorException
    • writeFromObjectIntoRowWithChangeRecord

      public void writeFromObjectIntoRowWithChangeRecord(ChangeRecord changeRecord, AbstractRecord row, AbstractSession session, DatabaseMapping.WriteType writeType)
      INTERNAL: Get the appropriate attribute value from the object and put it in the appropriate field of the database row. Loop through the reference objects and extract the primary keys and put them in the vector of "nested" rows.
      Overrides:
      writeFromObjectIntoRowWithChangeRecord in class DatabaseMapping
    • writeInsertFieldsIntoRow

      public void writeInsertFieldsIntoRow(AbstractRecord row, AbstractSession session)
      INTERNAL: Write the fields needed for insert into the template with null values.
      Overrides:
      writeInsertFieldsIntoRow in class DatabaseMapping
    • getFieldClassification

      public Class<?> getFieldClassification(DatabaseField fieldToClassify)
      INTERNAL: Return the classifiction for the field contained in the mapping. This is used to convert the row value to a consistent java value. By default this is unknown.
      Overrides:
      getFieldClassification in class DatabaseMapping
    • isCollectionMapping

      public boolean isCollectionMapping()
      Description copied from class: DatabaseMapping
      INTERNAL: Related mapping should implement this method to return true.
      Overrides:
      isCollectionMapping in class DatabaseMapping
      Returns:
      TODO
    • convertClassNamesToClasses

      public void convertClassNamesToClasses(ClassLoader classLoader)
      Description copied from class: DatabaseMapping
      INTERNAL: Convert all the class-name-based settings in this mapping to actual class-based settings This method is implemented by subclasses as necessary.
      Overrides:
      convertClassNamesToClasses in class DatabaseMapping
      Parameters:
      classLoader - TODO
    • compareForChange

      public ChangeRecord compareForChange(Object clone, Object backup, ObjectChangeSet owner, AbstractSession session)
      INTERNAL: Build and return the change record that results from comparing the two direct collection attributes.
      Specified by:
      compareForChange in class DatabaseMapping
      Parameters:
      clone - TODO
      backup - TODO
      owner - TODO
      session - TODO
      Returns:
      prototype.changeset.ChangeRecord TODO
    • compareObjects

      public boolean compareObjects(Object object1, Object object2, AbstractSession session)
      INTERNAL: Compare the attributes belonging to this mapping for the objects.
      Specified by:
      compareObjects in class DatabaseMapping
      Parameters:
      object1 - TODO
      object2 - TODO
      session - TODO
      Returns:
      TODO
    • mergeChangesIntoObject

      public void mergeChangesIntoObject(Object target, ChangeRecord changeRecord, Object source, MergeManager mergeManager, AbstractSession targetSession)
      INTERNAL: Merge changes from the source to the target object.
      Specified by:
      mergeChangesIntoObject in class DatabaseMapping
    • mergeIntoObject

      public void mergeIntoObject(Object target, boolean isTargetUnInitialized, Object source, MergeManager mergeManager, AbstractSession targetSession)
      INTERNAL: Merge changes from the source to the target object. Simply replace the entire target collection.
      Specified by:
      mergeIntoObject in class DatabaseMapping
    • simpleAddToCollectionChangeRecord

      public void simpleAddToCollectionChangeRecord(Object referenceKey, Object changeSetToAdd, ObjectChangeSet changeSet, AbstractSession session)
      ADVANCED: This method is used to have an object add to a collection once the changeSet is applied The referenceKey parameter should only be used for direct Maps.
      Overrides:
      simpleAddToCollectionChangeRecord in class DatabaseMapping
    • simpleRemoveFromCollectionChangeRecord

      public void simpleRemoveFromCollectionChangeRecord(Object referenceKey, Object changeSetToRemove, ObjectChangeSet changeSet, AbstractSession session)
      ADVANCED: This method is used to have an object removed from a collection once the changeSet is applied The referenceKey parameter should only be used for direct Maps.
      Overrides:
      simpleRemoveFromCollectionChangeRecord in class DatabaseMapping
    • createMapComponentFromRow

      public Object createMapComponentFromRow(AbstractRecord dbRow, ObjectBuildingQuery query, CacheKey parentCacheKey, AbstractSession session, boolean isTargetProtected)
      INTERNAL Called when a DatabaseMapping is used to map the key in a collection. Returns the key.