| 
 | EclipseLink 2.0.0, build 'v20091127-r5931' API Reference | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.eclipse.persistence.mappings.DatabaseMapping
org.eclipse.persistence.mappings.ForeignReferenceMapping
org.eclipse.persistence.mappings.CollectionMapping
public abstract class CollectionMapping
Purpose: Abstract class for relationship mappings which store collection of objects
| Field Summary | |
|---|---|
| protected  DataModifyQuery | changeOrderTargetQueryQuery used when order of list members is changed. | 
| protected  org.eclipse.persistence.internal.queries.ContainerPolicy | containerPolicy | 
| protected  ModifyQuery | deleteAllQueryUsed for delete all in m-m, dc and delete all optimization in 1-m. | 
| protected  boolean | hasCustomDeleteAllQuery | 
| protected  boolean | hasOrderBy | 
| protected  boolean | isListOrderFieldSupportedIndicates whether the mapping supports listOrderField, if it doesn't attempt to set listOrderField throws exception. | 
| protected  org.eclipse.persistence.internal.helper.DatabaseField | listOrderFieldField holds the order of elements in the list in the db, requires collection of type List, may be not null only in case isListOrderFieldSupported==true | 
| protected  OrderCorrectionType | orderCorrectionTypeSpecifies what should be done if the list of values read from listOrserField is invalid (there should be no nulls, no duplicates, no "holes"). | 
| Fields inherited from class org.eclipse.persistence.mappings.ForeignReferenceMapping | 
|---|
| cascadeDetach, cascadeMerge, cascadePersist, cascadeRefresh, cascadeRemove, forceInitializationOfSelectionCriteria, hasCustomSelectionQuery, indirectionPolicy, INNER_JOIN, isPrivateOwned, joinFetch, NONE, OUTER_JOIN, referenceClass, referenceClassName, referenceDescriptor, relationshipPartner, relationshipPartnerAttributeName, requiresTransientWeavedFields, selectionQuery, tempInitSession, usesBatchReading | 
| Fields inherited from class org.eclipse.persistence.mappings.DatabaseMapping | 
|---|
| attributeAccessor, attributeName, derivedIdMapping, derivesId, descriptor, fields, isJPAId, isLazy, isMapKeyMapping, isOptional, isPrimaryKeyMapping, isReadOnly, isRemotelyInitialized, mapsIdValue, NO_FIELDS, NO_WEIGHT, properties, weight, WEIGHT_1 | 
| Constructor Summary | |
|---|---|
| CollectionMapping()PUBLIC: Default constructor. | |
| Method Summary | |
|---|---|
|  void | addAggregateOrderBy(java.lang.String aggregateName,
                    java.lang.String queryKeyName,
                    boolean isDescending)PUBLIC: Provide order support for queryKeyName in ascending or descending order. | 
|  void | addAscendingOrdering(java.lang.String queryKeyName)PUBLIC: Provide order support for queryKeyName in ascending order | 
|  void | addDescendingOrdering(java.lang.String queryKeyName)PUBLIC: Provide order support for queryKeyName in descending order. | 
|  void | addOrderBy(java.lang.String queryKeyName,
           boolean isDescending)PUBLIC: Provide order support for queryKeyName in descending or ascending order. | 
|  java.lang.Object | buildBackupCloneForPartObject(java.lang.Object attributeValue,
                              java.lang.Object clone,
                              java.lang.Object backup,
                              org.eclipse.persistence.internal.sessions.UnitOfWorkImpl unitOfWork)INTERNAL: Used during building the backup shallow copy to copy the vector without re-registering the target objects. | 
|  org.eclipse.persistence.internal.sessions.ChangeRecord | buildChangeRecord(java.lang.Object clone,
                  org.eclipse.persistence.internal.sessions.ObjectChangeSet owner,
                  org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: Directly build a change record without comparison | 
|  java.lang.Object | buildCloneForPartObject(java.lang.Object attributeValue,
                        java.lang.Object original,
                        java.lang.Object clone,
                        org.eclipse.persistence.internal.sessions.UnitOfWorkImpl unitOfWork,
                        boolean isExisting)INTERNAL: Require for cloning, the part must be cloned. | 
|  void | buildCopy(java.lang.Object copy,
          java.lang.Object original,
          ObjectCopyingPolicy policy)INTERNAL: Copy of the attribute of the object. | 
|  java.lang.Object | buildElementClone(java.lang.Object element,
                  java.lang.Object parent,
                  org.eclipse.persistence.internal.sessions.UnitOfWorkImpl unitOfWork,
                  boolean isExisting)INTERNAL: Clone the element, if necessary. | 
| protected  void | buildListOrderField()INTERNAL: Verifies listOrderField's table, if none found sets the default one. | 
|  java.lang.Object[] | buildReferencesPKList(java.lang.Object entity,
                      java.lang.Object attribute,
                      org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: This method will access the target relationship and create a list of PKs of the target entities. | 
|  void | calculateDeferredChanges(org.eclipse.persistence.internal.sessions.ChangeRecord changeRecord,
                         org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: Used by AttributeLevelChangeTracking to update a changeRecord with calculated changes as apposed to detected changes. | 
|  void | cascadeDiscoverAndPersistUnregisteredNewObjects(java.lang.Object object,
                                                java.util.Map newObjects,
                                                java.util.Map unregisteredExistingObjects,
                                                java.util.Map visitedObjects,
                                                org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow)INTERNAL: Cascade discover and persist new objects during commit. | 
|  void | cascadeMerge(java.lang.Object sourceElement,
             org.eclipse.persistence.internal.sessions.MergeManager mergeManager)INTERNAL: Cascade the merge to the component object, if appropriate. | 
|  void | cascadePerformRemoveIfRequired(java.lang.Object object,
                               org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow,
                               java.util.Map visitedObjects)INTERNAL: Cascade perform delete through mappings that require the cascade | 
|  void | cascadePerformRemovePrivateOwnedObjectFromChangeSetIfRequired(java.lang.Object object,
                                                              org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow,
                                                              java.util.Map visitedObjects)INTERNAL: Cascade perform removal of orphaned private owned objects from the UnitOfWorkChangeSet | 
|  void | cascadeRegisterNewIfRequired(java.lang.Object object,
                             org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow,
                             java.util.Map visitedObjects)INTERNAL: Cascade registerNew for Create through mappings that require the cascade | 
|  java.lang.Object | clone()INTERNAL: The mapping clones itself to create deep copy. | 
|  void | compareCollectionsForChange(java.lang.Object oldCollection,
                            java.lang.Object newCollection,
                            org.eclipse.persistence.internal.sessions.ChangeRecord changeRecord,
                            org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: This method is used to calculate the differences between two collections. | 
|  org.eclipse.persistence.internal.sessions.ChangeRecord | compareForChange(java.lang.Object clone,
                 java.lang.Object backUp,
                 org.eclipse.persistence.internal.sessions.ObjectChangeSet owner,
                 org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: This method is used to create a change record from comparing two collections | 
| protected  boolean | compareLists(java.util.List firstList,
             java.util.List secondList,
             org.eclipse.persistence.internal.sessions.AbstractSession session,
             boolean withPrivateOwned)Compare two lists. | 
| protected  void | compareListsAndWrite(java.util.List previousList,
                     java.util.List currentList,
                     WriteObjectQuery query)INTERNAL: Old and new lists are compared and only the changes are written to the database. | 
|  boolean | compareObjects(java.lang.Object firstObject,
               java.lang.Object secondObject,
               org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: Compare the attributes belonging to this mapping for the objects. | 
| protected  void | compareObjectsAndWrite(java.lang.Object previousObjects,
                       java.lang.Object currentObjects,
                       WriteObjectQuery query)INTERNAL: The memory objects are compared and only the changes are written to the database | 
| protected  boolean | compareObjectsWithoutPrivateOwned(java.lang.Object firstCollection,
                                  java.lang.Object secondCollection,
                                  org.eclipse.persistence.internal.sessions.AbstractSession session)Compare two objects if their parts are not private owned | 
| protected  boolean | compareObjectsWithPrivateOwned(java.lang.Object firstCollection,
                               java.lang.Object secondCollection,
                               org.eclipse.persistence.internal.sessions.AbstractSession session)Compare two objects if their parts are private owned | 
|  void | convertClassNamesToClasses(java.lang.ClassLoader classLoader)INTERNAL: Convert all the class-name-based settings in this mapping to actual class-based settings This method is implemented by subclasses as necessary. | 
| protected  java.util.Vector | extractKeyFromTargetRow(org.eclipse.persistence.internal.sessions.AbstractRecord row,
                        org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: Extract the source primary key value from the target row. | 
| protected  java.util.Vector | extractPrimaryKeyFromRow(org.eclipse.persistence.internal.sessions.AbstractRecord row,
                         org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: Extract the primary key value from the source row. | 
|  java.lang.Object | extractResultFromBatchQuery(DatabaseQuery query,
                            org.eclipse.persistence.internal.sessions.AbstractRecord databaseRow,
                            org.eclipse.persistence.internal.sessions.AbstractSession session,
                            org.eclipse.persistence.internal.sessions.AbstractRecord argumentRow)INTERNAL: Extract the value from the batch optimized query. | 
|  void | fixRealObjectReferences(java.lang.Object object,
                        java.util.Map objectDescriptors,
                        java.util.Map processedObjects,
                        ObjectLevelReadQuery query,
                        RemoteSession session)INTERNAL: We are not using a remote valueholder so we need to replace the reference object(s) with the corresponding object(s) from the remote session. | 
|  org.eclipse.persistence.internal.queries.ContainerPolicy | getContainerPolicy()INTERNAL: Returns the receiver's containerPolicy. | 
| protected  ModifyQuery | getDeleteAllQuery() | 
|  Expression | getJoinCriteria(org.eclipse.persistence.internal.expressions.QueryKeyExpression exp)INTERNAL: Returns the join criteria stored in the mapping selection query. | 
|  org.eclipse.persistence.internal.helper.DatabaseField | getListOrderField()PUBLIC: Field holds the order of elements in the list in the db, requires collection of type List; may be not null only in case isListOrderFieldSupported==true. | 
|  Expression | getListOrderFieldExpression(Expression baseExpression)INTERNAL: Creates expression for listOrderField Precondition: listOrderField ! | 
|  java.lang.Object | getObjectCorrespondingTo(java.lang.Object object,
                         RemoteSession session,
                         java.util.Map objectDescriptors,
                         java.util.Map processedObjects,
                         ObjectLevelReadQuery query)INTERNAL: return the object on the client corresponding to the specified object. | 
|  java.util.List<Expression> | getOrderByQueryKeyExpressions()INTERNAL: Return the ordering query keys. | 
|  OrderCorrectionType | getOrderCorrectionType()PUBLIC: Specifies what should be done if the list of values read from listOrserField is invalid (there should be no nulls, no duplicates, no "holes"). | 
|  java.lang.Object | getRealCollectionAttributeValueFromObject(java.lang.Object object,
                                          org.eclipse.persistence.internal.sessions.AbstractSession session)Convenience method. | 
| protected  org.eclipse.persistence.internal.queries.ContainerPolicy | getSelectionQueryContainerPolicy()INTERNAL: Get the container policy from the selection query for this mapping. | 
|  java.util.List<org.eclipse.persistence.internal.helper.DatabaseField> | getTargetPrimaryKeyFields()INTERNAL: Returns list of primary key fields from the reference descriptor. | 
| protected  boolean | hasCustomDeleteAllQuery() | 
|  boolean | hasOrderBy()INTERNAL: Return true if ascending or descending ordering has been set on this mapping via the @OrderBy annotation. | 
|  void | initialize(org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: Initialize the state of mapping. | 
| protected  void | initializeChangeOrderTargetQuery(org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: Initialize changeOrderTargetQuery. | 
| protected  void | initializeListOrderField(org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: Initializes listOrderField. | 
| protected  void | initializeListOrderFieldTable(org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: Initializes listOrderField's table, does nothing by default. | 
|  boolean | isAttributeValueInstantiatedOrChanged(java.lang.Object object)INTERNAL: The referenced object is checked if it is instantiated or not, also check if it has been changed (as indirect collections avoid instantiation on add/remove. | 
|  boolean | isChangeTrackingSupported(Project project)INTERNAL: Return if this mapping supports change tracking. | 
|  boolean | isCollectionMapping()INTERNAL: Return whether this mapping is a Collection type. | 
|  boolean | isListOrderFieldSupported()PUBLIC: indicates whether the mapping supports listOrderField, if it doesn't attempt to set listOrderField throws exception. | 
|  void | iterateOnElement(org.eclipse.persistence.internal.descriptors.DescriptorIterator iterator,
                 java.lang.Object element)INTERNAL: Iterate on the specified element. | 
|  void | iterateOnRealAttributeValue(org.eclipse.persistence.internal.descriptors.DescriptorIterator iterator,
                            java.lang.Object realAttributeValue)INTERNAL: Iterate on the attribute value. | 
| protected  void | mergeChangesForCollectionMembers(java.lang.Object valueOfSource,
                                 java.lang.Object valueOfTarget,
                                 java.lang.Object target,
                                 org.eclipse.persistence.internal.sessions.MergeManager mergeManager,
                                 boolean fireChangeEvents)INTERNAL: Iterate through the collection and merge all the objects in the collection as appropriate. | 
|  void | mergeChangesIntoObject(java.lang.Object target,
                       org.eclipse.persistence.internal.sessions.ChangeRecord chgRecord,
                       java.lang.Object source,
                       org.eclipse.persistence.internal.sessions.MergeManager mergeManager)INTERNAL: Merge changes from the source to the target object. | 
|  void | mergeIntoObject(java.lang.Object target,
                boolean isTargetUnInitialized,
                java.lang.Object source,
                org.eclipse.persistence.internal.sessions.MergeManager mergeManager)INTERNAL: Merge changes from the source to the target object. | 
| protected  boolean | mustDeleteReferenceObjectsOneByOne()Return whether the reference objects must be deleted one by one, as opposed to with a single DELETE statement. | 
| protected  void | objectAddedDuringUpdate(ObjectLevelModifyQuery query,
                        java.lang.Object objectAdded,
                        org.eclipse.persistence.internal.sessions.ObjectChangeSet changeSet,
                        java.util.Map extraData)INTERNAL: An object was added to the collection during an update, insert it if private. | 
| protected  void | objectOrderChangedDuringUpdate(WriteObjectQuery query,
                               java.lang.Object orderChangedObject,
                               int orderIndex) | 
| protected  void | objectRemovedDuringUpdate(ObjectLevelModifyQuery query,
                          java.lang.Object objectDeleted,
                          java.util.Map extraData)INTERNAL: An object was removed to the collection during an update, delete it if private. | 
| protected  void | objectUnchangedDuringUpdate(ObjectLevelModifyQuery query,
                            java.lang.Object object)INTERNAL: An object is still in the collection, update it as it may have changed. | 
| protected  void | objectUnchangedDuringUpdate(ObjectLevelModifyQuery query,
                            java.lang.Object object,
                            java.util.Hashtable backupclones,
                            org.eclipse.persistence.internal.identitymaps.CacheKey keys)INTERNAL: An object is still in the collection, update it as it may have changed. | 
|  void | postCalculateChanges(ChangeRecord changeRecord,
                     org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow)INTERNAL: Overridden by mappings that require additional processing of the change record after the record has been calculated. | 
|  void | postDelete(DeleteObjectQuery query)INTERNAL: A subclass should implement this method if it wants different behavior. | 
|  void | postInitialize(org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: Ensure the container policy is post initialized | 
|  void | postInsert(WriteObjectQuery query)INTERNAL: A subclass should implement this method if it wants different behavior. | 
|  void | preInsert(WriteObjectQuery query)INTERNAL: Propagate preInsert event to container policy if necessary | 
|  ReadQuery | prepareNestedBatchQuery(ReadAllQuery query)INTERNAL: Clone and prepare the selection query as a nested batch read query. | 
| protected  void | prepareTranslationRow(org.eclipse.persistence.internal.sessions.AbstractRecord translationRow,
                      java.lang.Object object,
                      org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: copies the non primary key information into the row currently used only in ManyToMany | 
|  void | preUpdate(WriteObjectQuery query)INTERNAL: Propagate preUpdate event to container policy if necessary | 
| protected  java.lang.Object | readPrivateOwnedForObject(ObjectLevelModifyQuery modifyQuery)INTERNAL: All the privately owned parts are read | 
|  void | recordPrivateOwnedRemovals(java.lang.Object object,
                           org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow)INTERNAL: Overridden by mappings that require additional processing of the change record after the record has been calculated. | 
|  java.util.Map | replaceValueHoldersIn(java.lang.Object object,
                      org.eclipse.persistence.internal.sessions.remote.RemoteSessionController controller)INTERNAL: replace the value holders in the specified reference object(s) | 
|  void | setChangeListener(java.lang.Object clone,
                  java.beans.PropertyChangeListener listener,
                  org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow)INTERNAL: Set the change listener in the collection. | 
|  void | setContainerPolicy(org.eclipse.persistence.internal.queries.ContainerPolicy containerPolicy)ADVANCED: Configure the mapping to use a container policy. | 
|  void | setCustomDeleteAllQuery(ModifyQuery query)PUBLIC: The default delete all query for mapping can be overridden by specifying the new query. | 
|  void | setDeleteAllCall(Call call)PUBLIC: Set the receiver's delete all call. | 
| protected  void | setDeleteAllQuery(ModifyQuery query) | 
|  void | setDeleteAllSQLString(java.lang.String sqlString)PUBLIC: Set the receiver's delete all SQL string. | 
| protected  void | setHasCustomDeleteAllQuery(boolean bool) | 
|  void | setListOrderField(org.eclipse.persistence.internal.helper.DatabaseField field)PUBLIC: Field holds the order of elements in the list in the db, requires collection of type List. | 
|  void | setListOrderFieldName(java.lang.String fieldName)PUBLIC: Field holds the order of elements in the list in the db, requires collection of type List. | 
|  void | setOrderCorrectionType(OrderCorrectionType orderCorrectionType)PUBLIC: Specifies what should be done if the list of values read from listOrserField is invalid (there should be no nulls, no duplicates, no "holes"). | 
| protected  void | setSelectionQueryContainerPolicy(org.eclipse.persistence.internal.queries.ContainerPolicy containerPolicy)INTERNAL: Set the container policy on the selection query for this mapping. | 
|  void | setSessionName(java.lang.String name)PUBLIC: Set the name of the session to execute the mapping's queries under. | 
|  boolean | shouldUseListOrderFieldTableExpression()INTERNAL: Indicates whether getListOrderFieldExpression method should create field expression based on table expression. | 
|  void | simpleAddToCollectionChangeRecord(java.lang.Object referenceKey,
                                  java.lang.Object changeSetToAdd,
                                  org.eclipse.persistence.internal.sessions.ObjectChangeSet changeSet,
                                  org.eclipse.persistence.internal.sessions.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. | 
|  void | simpleRemoveFromCollectionChangeRecord(java.lang.Object referenceKey,
                                       java.lang.Object changeSetToRemove,
                                       org.eclipse.persistence.internal.sessions.ObjectChangeSet changeSet,
                                       org.eclipse.persistence.internal.sessions.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. | 
|  void | updateChangeRecord(java.lang.Object clone,
                   java.lang.Object newValue,
                   java.lang.Object oldValue,
                   org.eclipse.persistence.internal.sessions.ObjectChangeSet objectChangeSet,
                   org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow)INTERNAL: Either create a new change record or update with the new value. | 
|  void | updateCollectionChangeRecord(CollectionChangeEvent event,
                             org.eclipse.persistence.internal.sessions.ObjectChangeSet changeSet,
                             org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow)INTERNAL: Add or removes a new value and its change set to the collection change record based on the event passed in. | 
|  void | useCollectionClass(java.lang.Class concreteClass)PUBLIC: Configure the mapping to use an instance of the specified container class to hold the target objects. | 
|  void | useCollectionClassName(java.lang.String concreteClassName)INTERNAL: Not sure were this is used, MW? | 
|  void | useListClassName(java.lang.String concreteClassName)INTERNAL: Not sure were this is used, MW? | 
|  void | useMapClass(java.lang.Class concreteClass)PUBLIC: Configure the mapping to use an instance of the specified container class to hold the target objects. | 
|  void | useMapClass(java.lang.Class concreteClass,
            java.lang.String keyName)PUBLIC: Configure the mapping to use an instance of the specified container class to hold the target objects. | 
|  void | useMapClassName(java.lang.String concreteClassName,
                java.lang.String methodName)INTERNAL: Not sure were this is used, MW? | 
|  void | useSortedSetClass(java.lang.Class concreteClass,
                  java.util.Comparator comparator)PUBLIC: Configure the mapping to use an instance of the specified container class to hold the target objects. | 
|  void | useSortedSetClassName(java.lang.String className)INTERNAL: Configure the mapping to use an instance of the specified container class name to hold the target objects. | 
|  void | useSortedSetClassName(java.lang.String className,
                      java.lang.String comparatorClassName)INTERNAL: Configure the mapping to use an instance of the specified container class name to hold the target objects. | 
|  void | useTransparentCollection()PUBLIC: If transparent indirection is used, a special collection will be placed in the source object's attribute. | 
|  void | useTransparentList()PUBLIC: If transparent indirection is used, a special collection will be placed in the source object's attribute. | 
|  void | useTransparentMap(java.lang.String methodName)PUBLIC: If transparent indirection is used, a special map will be placed in the source object's attribute. | 
|  void | useTransparentSet()PUBLIC: If transparent indirection is used, a special collection will be placed in the source object's attribute. | 
|  void | validateBeforeInitialization(org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: To validate mappings declaration | 
|  java.lang.Object | valueFromPKList(java.lang.Object[] pks,
                org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: This method is used to load a relationship from a list of PKs. | 
| protected  java.lang.Object | valueFromRowInternalWithJoin(org.eclipse.persistence.internal.sessions.AbstractRecord row,
                             org.eclipse.persistence.internal.queries.JoinedAttributeManager joinManager,
                             ObjectBuildingQuery sourceQuery,
                             org.eclipse.persistence.internal.sessions.AbstractSession executionSession)INTERNAL: Return the value of the field from the row or a value holder on the query to obtain the object. | 
|  boolean | verifyDelete(java.lang.Object object,
             org.eclipse.persistence.internal.sessions.AbstractSession session)INTERNAL: Checks if object is deleted from the database or not. | 
| Methods inherited from class java.lang.Object | 
|---|
| equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait | 
| Field Detail | 
|---|
protected transient ModifyQuery deleteAllQuery
protected transient boolean hasCustomDeleteAllQuery
protected org.eclipse.persistence.internal.queries.ContainerPolicy containerPolicy
protected transient boolean hasOrderBy
protected org.eclipse.persistence.internal.helper.DatabaseField listOrderField
protected boolean isListOrderFieldSupported
protected transient DataModifyQuery changeOrderTargetQuery
protected OrderCorrectionType orderCorrectionType
| Constructor Detail | 
|---|
public CollectionMapping()
| Method Detail | 
|---|
public void addAscendingOrdering(java.lang.String queryKeyName)
public void addDescendingOrdering(java.lang.String queryKeyName)
public void addOrderBy(java.lang.String queryKeyName,
                       boolean isDescending)
public void addAggregateOrderBy(java.lang.String aggregateName,
                                java.lang.String queryKeyName,
                                boolean isDescending)
public java.lang.Object buildBackupCloneForPartObject(java.lang.Object attributeValue,
                                                      java.lang.Object clone,
                                                      java.lang.Object backup,
                                                      org.eclipse.persistence.internal.sessions.UnitOfWorkImpl unitOfWork)
buildBackupCloneForPartObject in class ForeignReferenceMapping
public java.lang.Object buildCloneForPartObject(java.lang.Object attributeValue,
                                                java.lang.Object original,
                                                java.lang.Object clone,
                                                org.eclipse.persistence.internal.sessions.UnitOfWorkImpl unitOfWork,
                                                boolean isExisting)
buildCloneForPartObject in class ForeignReferenceMapping
public void buildCopy(java.lang.Object copy,
                      java.lang.Object original,
                      ObjectCopyingPolicy policy)
buildCopy in class DatabaseMapping
public java.lang.Object buildElementClone(java.lang.Object element,
                                          java.lang.Object parent,
                                          org.eclipse.persistence.internal.sessions.UnitOfWorkImpl unitOfWork,
                                          boolean isExisting)
public java.lang.Object[] buildReferencesPKList(java.lang.Object entity,
                                                java.lang.Object attribute,
                                                org.eclipse.persistence.internal.sessions.AbstractSession session)
buildReferencesPKList in class ForeignReferenceMapping
public void cascadePerformRemoveIfRequired(java.lang.Object object,
                                           org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow,
                                           java.util.Map visitedObjects)
cascadePerformRemoveIfRequired in class DatabaseMapping
public void cascadePerformRemovePrivateOwnedObjectFromChangeSetIfRequired(java.lang.Object object,
                                                                          org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow,
                                                                          java.util.Map visitedObjects)
cascadePerformRemovePrivateOwnedObjectFromChangeSetIfRequired in class DatabaseMapping
public void cascadeDiscoverAndPersistUnregisteredNewObjects(java.lang.Object object,
                                                            java.util.Map newObjects,
                                                            java.util.Map unregisteredExistingObjects,
                                                            java.util.Map visitedObjects,
                                                            org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow)
cascadeDiscoverAndPersistUnregisteredNewObjects in class DatabaseMapping
public void cascadeRegisterNewIfRequired(java.lang.Object object,
                                         org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow,
                                         java.util.Map visitedObjects)
cascadeRegisterNewIfRequired in class DatabaseMapping
public void calculateDeferredChanges(org.eclipse.persistence.internal.sessions.ChangeRecord changeRecord,
                                     org.eclipse.persistence.internal.sessions.AbstractSession session)
calculateDeferredChanges in class DatabaseMapping
public void cascadeMerge(java.lang.Object sourceElement,
                         org.eclipse.persistence.internal.sessions.MergeManager mergeManager)
cascadeMerge in class DatabaseMappingpublic java.lang.Object clone()
clone in class ForeignReferenceMapping
public void compareCollectionsForChange(java.lang.Object oldCollection,
                                        java.lang.Object newCollection,
                                        org.eclipse.persistence.internal.sessions.ChangeRecord changeRecord,
                                        org.eclipse.persistence.internal.sessions.AbstractSession session)
public org.eclipse.persistence.internal.sessions.ChangeRecord compareForChange(java.lang.Object clone,
                                                                               java.lang.Object backUp,
                                                                               org.eclipse.persistence.internal.sessions.ObjectChangeSet owner,
                                                                               org.eclipse.persistence.internal.sessions.AbstractSession session)
compareForChange in class DatabaseMapping
public boolean compareObjects(java.lang.Object firstObject,
                              java.lang.Object secondObject,
                              org.eclipse.persistence.internal.sessions.AbstractSession session)
compareObjects in class ForeignReferenceMapping
protected void compareObjectsAndWrite(java.lang.Object previousObjects,
                                      java.lang.Object currentObjects,
                                      WriteObjectQuery query)
                               throws DatabaseException,
                                      OptimisticLockException
DatabaseException
OptimisticLockException
protected void compareListsAndWrite(java.util.List previousList,
                                    java.util.List currentList,
                                    WriteObjectQuery query)
                             throws DatabaseException,
                                    OptimisticLockException
DatabaseException
OptimisticLockException
protected boolean compareObjectsWithoutPrivateOwned(java.lang.Object firstCollection,
                                                    java.lang.Object secondCollection,
                                                    org.eclipse.persistence.internal.sessions.AbstractSession session)
compareObjectsWithoutPrivateOwned in class ForeignReferenceMapping
protected boolean compareObjectsWithPrivateOwned(java.lang.Object firstCollection,
                                                 java.lang.Object secondCollection,
                                                 org.eclipse.persistence.internal.sessions.AbstractSession session)
compareObjectsWithPrivateOwned in class ForeignReferenceMapping
protected boolean compareLists(java.util.List firstList,
                               java.util.List secondList,
                               org.eclipse.persistence.internal.sessions.AbstractSession session,
                               boolean withPrivateOwned)
public void convertClassNamesToClasses(java.lang.ClassLoader classLoader)
convertClassNamesToClasses in class ForeignReferenceMappingclassLoader - 
public java.lang.Object extractResultFromBatchQuery(DatabaseQuery query,
                                                    org.eclipse.persistence.internal.sessions.AbstractRecord databaseRow,
                                                    org.eclipse.persistence.internal.sessions.AbstractSession session,
                                                    org.eclipse.persistence.internal.sessions.AbstractRecord argumentRow)
extractResultFromBatchQuery in class ForeignReferenceMapping
protected java.util.Vector extractKeyFromTargetRow(org.eclipse.persistence.internal.sessions.AbstractRecord row,
                                                   org.eclipse.persistence.internal.sessions.AbstractSession session)
protected java.util.Vector extractPrimaryKeyFromRow(org.eclipse.persistence.internal.sessions.AbstractRecord row,
                                                    org.eclipse.persistence.internal.sessions.AbstractSession session)
public void fixRealObjectReferences(java.lang.Object object,
                                    java.util.Map objectDescriptors,
                                    java.util.Map processedObjects,
                                    ObjectLevelReadQuery query,
                                    RemoteSession session)
fixRealObjectReferences in class DatabaseMappingpublic org.eclipse.persistence.internal.queries.ContainerPolicy getContainerPolicy()
getContainerPolicy in interface ContainerMappinggetContainerPolicy in class DatabaseMappingprotected ModifyQuery getDeleteAllQuery()
public Expression getJoinCriteria(org.eclipse.persistence.internal.expressions.QueryKeyExpression exp)
getJoinCriteria in class ForeignReferenceMapping
public java.lang.Object getObjectCorrespondingTo(java.lang.Object object,
                                                 RemoteSession session,
                                                 java.util.Map objectDescriptors,
                                                 java.util.Map processedObjects,
                                                 ObjectLevelReadQuery query)
getObjectCorrespondingTo in class ForeignReferenceMappingpublic java.util.List<Expression> getOrderByQueryKeyExpressions()
protected org.eclipse.persistence.internal.queries.ContainerPolicy getSelectionQueryContainerPolicy()
public java.lang.Object getRealCollectionAttributeValueFromObject(java.lang.Object object,
                                                                  org.eclipse.persistence.internal.sessions.AbstractSession session)
                                                           throws DescriptorException
getRealCollectionAttributeValueFromObject in class DatabaseMappingDescriptorExceptionpublic org.eclipse.persistence.internal.helper.DatabaseField getListOrderField()
public java.util.List<org.eclipse.persistence.internal.helper.DatabaseField> getTargetPrimaryKeyFields()
public OrderCorrectionType getOrderCorrectionType()
protected boolean hasCustomDeleteAllQuery()
public boolean hasOrderBy()
public void initialize(org.eclipse.persistence.internal.sessions.AbstractSession session)
                throws DescriptorException
initialize in class ForeignReferenceMappingDescriptorExceptionprotected void initializeListOrderField(org.eclipse.persistence.internal.sessions.AbstractSession session)
protected void initializeListOrderFieldTable(org.eclipse.persistence.internal.sessions.AbstractSession session)
protected void buildListOrderField()
public Expression getListOrderFieldExpression(Expression baseExpression)
public boolean shouldUseListOrderFieldTableExpression()
protected void initializeChangeOrderTargetQuery(org.eclipse.persistence.internal.sessions.AbstractSession session)
public boolean isCollectionMapping()
isCollectionMapping in class DatabaseMappingpublic boolean isAttributeValueInstantiatedOrChanged(java.lang.Object object)
public void iterateOnElement(org.eclipse.persistence.internal.descriptors.DescriptorIterator iterator,
                             java.lang.Object element)
public void iterateOnRealAttributeValue(org.eclipse.persistence.internal.descriptors.DescriptorIterator iterator,
                                        java.lang.Object realAttributeValue)
iterateOnRealAttributeValue in class ForeignReferenceMappingprotected boolean mustDeleteReferenceObjectsOneByOne()
public void mergeChangesIntoObject(java.lang.Object target,
                                   org.eclipse.persistence.internal.sessions.ChangeRecord chgRecord,
                                   java.lang.Object source,
                                   org.eclipse.persistence.internal.sessions.MergeManager mergeManager)
mergeChangesIntoObject in class DatabaseMapping
public void mergeIntoObject(java.lang.Object target,
                            boolean isTargetUnInitialized,
                            java.lang.Object source,
                            org.eclipse.persistence.internal.sessions.MergeManager mergeManager)
mergeIntoObject in class DatabaseMapping
protected void mergeChangesForCollectionMembers(java.lang.Object valueOfSource,
                                                java.lang.Object valueOfTarget,
                                                java.lang.Object target,
                                                org.eclipse.persistence.internal.sessions.MergeManager mergeManager,
                                                boolean fireChangeEvents)
wrappedObject - valueOfTarget - target - mergeManager - fireChangeEvents - 
protected void objectAddedDuringUpdate(ObjectLevelModifyQuery query,
                                       java.lang.Object objectAdded,
                                       org.eclipse.persistence.internal.sessions.ObjectChangeSet changeSet,
                                       java.util.Map extraData)
                                throws DatabaseException,
                                       OptimisticLockException
DatabaseException
OptimisticLockException
protected void objectOrderChangedDuringUpdate(WriteObjectQuery query,
                                              java.lang.Object orderChangedObject,
                                              int orderIndex)
protected void objectRemovedDuringUpdate(ObjectLevelModifyQuery query,
                                         java.lang.Object objectDeleted,
                                         java.util.Map extraData)
                                  throws DatabaseException,
                                         OptimisticLockException
DatabaseException
OptimisticLockException
protected void objectUnchangedDuringUpdate(ObjectLevelModifyQuery query,
                                           java.lang.Object object)
                                    throws DatabaseException,
                                           OptimisticLockException
DatabaseException
OptimisticLockException
public void postCalculateChanges(ChangeRecord changeRecord,
                                 org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow)
postCalculateChanges in class DatabaseMapping
public void recordPrivateOwnedRemovals(java.lang.Object object,
                                       org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow)
recordPrivateOwnedRemovals in class DatabaseMappingpublic ReadQuery prepareNestedBatchQuery(ReadAllQuery query)
prepareNestedBatchQuery in class ForeignReferenceMapping
protected void prepareTranslationRow(org.eclipse.persistence.internal.sessions.AbstractRecord translationRow,
                                     java.lang.Object object,
                                     org.eclipse.persistence.internal.sessions.AbstractSession session)
public void postDelete(DeleteObjectQuery query)
                throws DatabaseException
postDelete in class DatabaseMappingDatabaseExceptionpublic void postInitialize(org.eclipse.persistence.internal.sessions.AbstractSession session)
postInitialize in class DatabaseMapping
public void postInsert(WriteObjectQuery query)
                throws DatabaseException
postInsert in class DatabaseMappingDatabaseException
public void preInsert(WriteObjectQuery query)
               throws DatabaseException,
                      OptimisticLockException
preInsert in class DatabaseMappingDatabaseException
OptimisticLockException
public void preUpdate(WriteObjectQuery query)
               throws DatabaseException
preUpdate in class DatabaseMappingDatabaseException
protected void objectUnchangedDuringUpdate(ObjectLevelModifyQuery query,
                                           java.lang.Object object,
                                           java.util.Hashtable backupclones,
                                           org.eclipse.persistence.internal.identitymaps.CacheKey keys)
                                    throws DatabaseException,
                                           OptimisticLockException
DatabaseException
OptimisticLockException
protected java.lang.Object readPrivateOwnedForObject(ObjectLevelModifyQuery modifyQuery)
                                              throws DatabaseException
DatabaseException
public java.util.Map replaceValueHoldersIn(java.lang.Object object,
                                           org.eclipse.persistence.internal.sessions.remote.RemoteSessionController controller)
replaceValueHoldersIn in class ForeignReferenceMappingpublic void setContainerPolicy(org.eclipse.persistence.internal.queries.ContainerPolicy containerPolicy)
setContainerPolicy in interface ContainerMappingpublic void setCustomDeleteAllQuery(ModifyQuery query)
protected void setDeleteAllQuery(ModifyQuery query)
public void setDeleteAllSQLString(java.lang.String sqlString)
public void setDeleteAllCall(Call call)
protected void setHasCustomDeleteAllQuery(boolean bool)
protected void setSelectionQueryContainerPolicy(org.eclipse.persistence.internal.queries.ContainerPolicy containerPolicy)
public void setSessionName(java.lang.String name)
public void simpleAddToCollectionChangeRecord(java.lang.Object referenceKey,
                                              java.lang.Object changeSetToAdd,
                                              org.eclipse.persistence.internal.sessions.ObjectChangeSet changeSet,
                                              org.eclipse.persistence.internal.sessions.AbstractSession session)
simpleAddToCollectionChangeRecord in class DatabaseMapping
public void simpleRemoveFromCollectionChangeRecord(java.lang.Object referenceKey,
                                                   java.lang.Object changeSetToRemove,
                                                   org.eclipse.persistence.internal.sessions.ObjectChangeSet changeSet,
                                                   org.eclipse.persistence.internal.sessions.AbstractSession session)
simpleRemoveFromCollectionChangeRecord in class DatabaseMapping
public void updateChangeRecord(java.lang.Object clone,
                               java.lang.Object newValue,
                               java.lang.Object oldValue,
                               org.eclipse.persistence.internal.sessions.ObjectChangeSet objectChangeSet,
                               org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow)
updateChangeRecord in class DatabaseMapping
public void updateCollectionChangeRecord(CollectionChangeEvent event,
                                         org.eclipse.persistence.internal.sessions.ObjectChangeSet changeSet,
                                         org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow)
updateCollectionChangeRecord in class DatabaseMapping
public void setChangeListener(java.lang.Object clone,
                              java.beans.PropertyChangeListener listener,
                              org.eclipse.persistence.internal.sessions.UnitOfWorkImpl uow)
setChangeListener in class DatabaseMappingpublic boolean isListOrderFieldSupported()
public void setListOrderField(org.eclipse.persistence.internal.helper.DatabaseField field)
public void setListOrderFieldName(java.lang.String fieldName)
public void setOrderCorrectionType(OrderCorrectionType orderCorrectionType)
public void useCollectionClass(java.lang.Class concreteClass)
The container class must implement (directly or indirectly) the
 java.util.Collection interface.
useCollectionClass in interface ContainerMapping
public void useSortedSetClass(java.lang.Class concreteClass,
                              java.util.Comparator comparator)
The container class must implement (directly or indirectly) the
 java.util.SortedSet interface.
public void useSortedSetClassName(java.lang.String className)
The container class must implement (directly or indirectly) the
 java.util.SortedSet interface.
public void useSortedSetClassName(java.lang.String className,
                                  java.lang.String comparatorClassName)
The container class must implement (directly or indirectly) the
 java.util.SortedSet interface.
public void useCollectionClassName(java.lang.String concreteClassName)
public void useListClassName(java.lang.String concreteClassName)
public void useMapClass(java.lang.Class concreteClass,
                        java.lang.String keyName)
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.
useMapClass in interface ContainerMappingpublic void useMapClass(java.lang.Class concreteClass)
Map is an instance of the composite primary key class.
 To facilitate resolving the primary key class, the mapping's referenceClass must set before calling this method.
 The container class must implement (directly or indirectly) the
 java.util.Map interface.
public void useMapClassName(java.lang.String concreteClassName,
                            java.lang.String methodName)
public void useTransparentCollection()
public void useTransparentSet()
public void useTransparentList()
public void useTransparentMap(java.lang.String methodName)
The key used in the Map is the value returned by a call to the zero parameter method named methodName. The method should be a zero argument method implemented (or inherited) by the value to be inserted into the Map.
public void validateBeforeInitialization(org.eclipse.persistence.internal.sessions.AbstractSession session)
                                  throws DescriptorException
validateBeforeInitialization in class ForeignReferenceMappingDescriptorException
public boolean verifyDelete(java.lang.Object object,
                            org.eclipse.persistence.internal.sessions.AbstractSession session)
                     throws DatabaseException
verifyDelete in class DatabaseMappingDatabaseExceptionpublic boolean isChangeTrackingSupported(Project project)
isChangeTrackingSupported in class DatabaseMapping
public org.eclipse.persistence.internal.sessions.ChangeRecord buildChangeRecord(java.lang.Object clone,
                                                                                org.eclipse.persistence.internal.sessions.ObjectChangeSet owner,
                                                                                org.eclipse.persistence.internal.sessions.AbstractSession session)
buildChangeRecord in class DatabaseMapping
public java.lang.Object valueFromPKList(java.lang.Object[] pks,
                                        org.eclipse.persistence.internal.sessions.AbstractSession session)
valueFromPKList in class ForeignReferenceMapping
protected java.lang.Object valueFromRowInternalWithJoin(org.eclipse.persistence.internal.sessions.AbstractRecord row,
                                                        org.eclipse.persistence.internal.queries.JoinedAttributeManager joinManager,
                                                        ObjectBuildingQuery sourceQuery,
                                                        org.eclipse.persistence.internal.sessions.AbstractSession executionSession)
                                                 throws DatabaseException
valueFromRowInternalWithJoin in class ForeignReferenceMappingDatabaseException| 
 | EclipseLink 2.0.0, build 'v20091127-r5931' API Reference | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||