Class ClassDescriptor

All Implemented Interfaces:
Serializable, Cloneable
Direct Known Subclasses:
EISDescriptor, RelationalDescriptor, XMLDescriptor

Purpose: Abstract descriptor class for defining persistence information on a class. This class provides the data independent behavior and is subclassed, for relational, object-relational, EIS, XML, etc.

See Also:
  • Field Details

    • javaClass

      protected Class<?> javaClass
    • javaClassName

      protected String javaClassName
    • tables

      protected Vector<DatabaseTable> tables
    • defaultTable

      protected transient DatabaseTable defaultTable
    • primaryKeyFields

      protected List<DatabaseField> primaryKeyFields
    • additionalTablePrimaryKeyFields

      protected Map<DatabaseTable,Map<DatabaseField,DatabaseField>> additionalTablePrimaryKeyFields
    • multipleTableInsertOrder

      protected transient List<DatabaseTable> multipleTableInsertOrder
    • multipleTableForeignKeys

      protected Map<DatabaseTable,Set<DatabaseTable>> multipleTableForeignKeys
    • isCascadeOnDeleteSetOnDatabaseOnSecondaryTables

      protected boolean isCascadeOnDeleteSetOnDatabaseOnSecondaryTables
      Support delete cascading on the database for multiple and inheritance tables.
    • fields

      protected transient Vector<DatabaseField> fields
    • allFields

      protected transient Vector<DatabaseField> allFields
    • selectionFields

      protected transient List<DatabaseField> selectionFields
    • allSelectionFields

      protected transient List<DatabaseField> allSelectionFields
    • returnFieldsToGenerateInsert

      protected transient Vector<DatabaseField> returnFieldsToGenerateInsert
    • returnFieldsToGenerateUpdate

      protected transient Vector<DatabaseField> returnFieldsToGenerateUpdate
    • returnFieldsToMergeInsert

      protected transient List<DatabaseField> returnFieldsToMergeInsert
    • returnFieldsToMergeUpdate

      protected transient List<DatabaseField> returnFieldsToMergeUpdate
    • mappings

      protected Vector<DatabaseMapping> mappings
    • referencingClasses

      protected Set<ClassDescriptor> referencingClasses
    • lockableMappings

      protected List<DatabaseMapping> lockableMappings
    • queryKeys

      protected Map<String,QueryKey> queryKeys
    • sequenceNumberName

      protected String sequenceNumberName
    • sequenceNumberField

      protected DatabaseField sequenceNumberField
    • sessionName

      protected transient String sessionName
    • constraintDependencies

      protected transient Vector constraintDependencies
    • amendmentMethodName

      protected transient String amendmentMethodName
    • amendmentClass

      protected transient Class<?> amendmentClass
    • amendmentClassName

      protected String amendmentClassName
    • alias

      protected String alias
    • shouldBeReadOnly

      protected boolean shouldBeReadOnly
    • shouldAlwaysConformResultsInUnitOfWork

      protected boolean shouldAlwaysConformResultsInUnitOfWork
    • shouldRegisterResultsInUnitOfWork

      protected boolean shouldRegisterResultsInUnitOfWork
    • queryManager

      protected DescriptorQueryManager queryManager
    • copyPolicy

      protected CopyPolicy copyPolicy
    • copyPolicyClassName

      protected String copyPolicyClassName
    • interfacePolicy

      protected InterfacePolicy interfacePolicy
    • optimisticLockingPolicy

      protected OptimisticLockingPolicy optimisticLockingPolicy
    • cascadeLockingPolicies

      protected transient List<CascadeLockingPolicy> cascadeLockingPolicies
    • wrapperPolicy

      protected WrapperPolicy wrapperPolicy
    • changePolicy

      protected ObjectChangePolicy changePolicy
    • returningPolicy

      protected ReturningPolicy returningPolicy
    • returningPolicies

      protected List<ReturningPolicy> returningPolicies
    • historyPolicy

      protected HistoryPolicy historyPolicy
    • partitioningPolicyName

      protected String partitioningPolicyName
    • partitioningPolicy

      protected PartitioningPolicy partitioningPolicy
    • cmpPolicy

      protected CMPPolicy cmpPolicy
    • cachePolicy

      protected CachePolicy cachePolicy
    • multitenantPolicy

      protected MultitenantPolicy multitenantPolicy
    • serializedObjectPolicy

      protected SerializedObjectPolicy serializedObjectPolicy
    • fetchGroupManager

      protected FetchGroupManager fetchGroupManager
    • properties

      protected Map properties
      Additional properties may be added.
    • unconvertedProperties

      protected Map<String,List<String>> unconvertedProperties
      Allow the user to defined un-converted properties which will be initialized at runtime.
    • initializationStage

      protected transient int initializationStage
    • interfaceInitializationStage

      protected transient int interfaceInitializationStage
    • UNINITIALIZED

      protected static final int UNINITIALIZED
      The following are the [initializationStage] states the descriptor passes through during the initialization.
      See Also:
    • PREINITIALIZED

      protected static final int PREINITIALIZED
      See Also:
    • INITIALIZED

      protected static final int INITIALIZED
      See Also:
    • POST_INITIALIZED

      protected static final int POST_INITIALIZED
      See Also:
    • ERROR

      protected static final int ERROR
      See Also:
    • descriptorType

      protected int descriptorType
    • NORMAL

      protected static final int NORMAL
      Define valid descriptor types.
      See Also:
    • INTERFACE

      protected static final int INTERFACE
      See Also:
    • AGGREGATE

      protected static final int AGGREGATE
      See Also:
    • AGGREGATE_COLLECTION

      protected static final int AGGREGATE_COLLECTION
      See Also:
    • shouldOrderMappings

      protected boolean shouldOrderMappings
    • cacheInvalidationPolicy

      protected CacheInvalidationPolicy cacheInvalidationPolicy
    • shouldAcquireCascadedLocks

      protected boolean shouldAcquireCascadedLocks
      PERF: Used to optimize cache locking to only acquire deferred locks when required (no-indirection).
    • cascadedLockingInitialized

      protected boolean cascadedLockingInitialized
      INTERNAL: flag to indicate the initialization state of cascade locking for this descriptor
    • hasSimplePrimaryKey

      protected boolean hasSimplePrimaryKey
      PERF: Compute and store if the primary key is simple (direct-mapped) to allow fast extraction.
    • hasMultipleTableConstraintDependecy

      protected boolean hasMultipleTableConstraintDependecy
      Defines if any mapping reference a field in a secondary table. This is used to disable deferring multiple table writes.
    • UNDEFINED_OBJECT_CHANGE_BEHAVIOR

      public static final int UNDEFINED_OBJECT_CHANGE_BEHAVIOR
      See Also:
    • SEND_OBJECT_CHANGES

      public static final int SEND_OBJECT_CHANGES
      See Also:
    • INVALIDATE_CHANGED_OBJECTS

      public static final int INVALIDATE_CHANGED_OBJECTS
      See Also:
    • SEND_NEW_OBJECTS_WITH_CHANGES

      public static final int SEND_NEW_OBJECTS_WITH_CHANGES
      See Also:
    • DO_NOT_SEND_CHANGES

      public static final int DO_NOT_SEND_CHANGES
      See Also:
    • UNDEFINED_ISOLATATION

      public static final int UNDEFINED_ISOLATATION
      See Also:
    • USE_SESSION_CACHE_AFTER_TRANSACTION

      public static final int USE_SESSION_CACHE_AFTER_TRANSACTION
      See Also:
    • ISOLATE_NEW_DATA_AFTER_TRANSACTION

      public static final int ISOLATE_NEW_DATA_AFTER_TRANSACTION
      See Also:
    • ISOLATE_CACHE_AFTER_TRANSACTION

      public static final int ISOLATE_CACHE_AFTER_TRANSACTION
      See Also:
    • ISOLATE_FROM_CLIENT_SESSION

      public static final int ISOLATE_FROM_CLIENT_SESSION
      See Also:
    • ISOLATE_CACHE_ALWAYS

      public static final int ISOLATE_CACHE_ALWAYS
      See Also:
    • shouldUseFullChangeSetsForNewObjects

      public static boolean shouldUseFullChangeSetsForNewObjects
      INTERNAL: Backdoor for using changes sets for new objects.
    • isNativeConnectionRequired

      protected boolean isNativeConnectionRequired
      Allow connection unwrapping to be configured.
    • idValidation

      protected IdValidation idValidation
      Allow zero primary key validation to be configured.
    • primaryKeyIdValidations

      protected List<IdValidation> primaryKeyIdValidations
      Allow zero primary key validation to be configured per field.
    • derivesIdMappings

      protected Map<String,DatabaseMapping> derivesIdMappings
    • defaultQueryRedirector

      protected QueryRedirector defaultQueryRedirector
    • defaultReadAllQueryRedirector

      protected QueryRedirector defaultReadAllQueryRedirector
    • defaultReadObjectQueryRedirector

      protected QueryRedirector defaultReadObjectQueryRedirector
    • defaultReportQueryRedirector

      protected QueryRedirector defaultReportQueryRedirector
    • defaultUpdateObjectQueryRedirector

      protected QueryRedirector defaultUpdateObjectQueryRedirector
    • defaultInsertObjectQueryRedirector

      protected QueryRedirector defaultInsertObjectQueryRedirector
    • defaultDeleteObjectQueryRedirector

      protected QueryRedirector defaultDeleteObjectQueryRedirector
    • defaultQueryRedirectorClassName

      protected String defaultQueryRedirectorClassName
    • defaultReadAllQueryRedirectorClassName

      protected String defaultReadAllQueryRedirectorClassName
    • defaultReadObjectQueryRedirectorClassName

      protected String defaultReadObjectQueryRedirectorClassName
    • defaultReportQueryRedirectorClassName

      protected String defaultReportQueryRedirectorClassName
    • defaultUpdateObjectQueryRedirectorClassName

      protected String defaultUpdateObjectQueryRedirectorClassName
    • defaultInsertObjectQueryRedirectorClassName

      protected String defaultInsertObjectQueryRedirectorClassName
    • defaultDeleteObjectQueryRedirectorClassName

      protected String defaultDeleteObjectQueryRedirectorClassName
    • sequence

      protected Sequence sequence
      Store the Sequence used for the descriptor.
    • mappingsPostCalculateChanges

      protected List<DatabaseMapping> mappingsPostCalculateChanges
      Mappings that require postCalculateChanges method to be called
    • mappingsPostCalculateChangesOnDeleted

      protected List<DatabaseMapping> mappingsPostCalculateChangesOnDeleted
      Mappings that require postCalculateChangesOnDeleted method to be called
    • additionalAggregateCollectionKeyFields

      protected transient List<DatabaseField> additionalAggregateCollectionKeyFields
      used by aggregate descriptors to hold additional fields needed when they are stored in an AggregatateCollection These fields are generally foreign key fields that are required in addition to the fields in the descriptor's mappings to uniquely identify the Aggregate
    • preDeleteMappings

      protected List<DatabaseMapping> preDeleteMappings
      stores a list of mappings that require preDelete as a group prior to the delete individually
    • additionalWritableMapKeyFields

      protected transient List<DatabaseField> additionalWritableMapKeyFields
      stores fields that are written by Map key mappings so they can be checked for multiple writable mappings
    • hasRelationships

      protected boolean hasRelationships
      whether this descriptor has any relationships through its mappings, through inheritance, or through aggregates
    • foreignKeyValuesForCaching

      protected Set<DatabaseField> foreignKeyValuesForCaching
      Stores a set of FK fields that will be cached to later retrieve noncacheable mappings
    • hasNoncacheableMappings

      protected boolean hasNoncacheableMappings
      caches if this descriptor has any non cacheable mappings
    • weavingUsesPropertyAccess

      protected boolean weavingUsesPropertyAccess
      This flag stores whether this descriptor is using Property access based on JPA semantics. It is used to modify the behavior of our weaving functionality as it pertains to adding annotations to fields
    • virtualAttributeMethods

      protected List<VirtualAttributeMethodInfo> virtualAttributeMethods
      A list of methods that are used by virtual mappings. This list is used to control weaving of methods used for virtual access
    • accessorTree

      protected List<AttributeAccessor> accessorTree
      A list of AttributeAccessors in order of access from root to leaf to arrive at current AggregateDescriptor. Only application for Aggregate Descriptors.
    • descriptorCustomizerClassName

      protected String descriptorCustomizerClassName
      JPA DescriptorCustomizer list stored here to preserve it when caching the project
    • shouldLockForClone

      protected boolean shouldLockForClone
      This flag controls if a UOW should acquire locks for clone or simple clone the instance passed to registerExistingObject. If the IdentityMap type does not have concurrent access this can save a return to the identity map for cloning.
  • Constructor Details

    • ClassDescriptor

      public ClassDescriptor()
      PUBLIC: Return a new descriptor.
  • Method Details

    • addAbstractQueryKey

      public void addAbstractQueryKey(String queryKeyName)
      PUBLIC: This method should only be used for interface descriptors. It adds an abstract query key to the interface descriptor. Any implementors of that interface must define the query key defined by this abstract query key.
    • addCascadeLockingPolicy

      public void addCascadeLockingPolicy(CascadeLockingPolicy policy)
      INTERNAL: Add the cascade locking policy to all children that have a relationship to this descriptor either by inheritance or by encapsulation/aggregation.
      Parameters:
      policy - - the CascadeLockingPolicy
    • addConstraintDependencies

      public void addConstraintDependencies(Class<?> dependencies)
      ADVANCED: EclipseLink automatically orders database access through the foreign key information provided in 1:1 and 1:m mappings. In some case when 1:1 are not defined it may be required to tell the descriptor about a constraint, this defines that this descriptor has a foreign key constraint to another class and must be inserted after instances of the other class.
    • addConstraintDependency

      public void addConstraintDependency(Class<?> dependencies)
      ADVANCED: EclipseLink automatically orders database access through the foreign key information provided in 1:1 and 1:m mappings. In some case when 1:1 are not defined it may be required to tell the descriptor about a constraint, this defines that this descriptor has a foreign key constraint to another class and must be inserted after instances of the other class.
    • newDirectMapping

      public AbstractDirectMapping newDirectMapping()
      Return a new direct/basic mapping for this type of descriptor.
    • newAggregateMapping

      public AggregateMapping newAggregateMapping()
      Return a new aggregate/embedded mapping for this type of descriptor.
    • newAggregateCollectionMapping

      public DatabaseMapping newAggregateCollectionMapping()
      Return a new aggregate collection/element collection mapping for this type of descriptor.
    • newDirectCollectionMapping

      public DatabaseMapping newDirectCollectionMapping()
      Return a new direct collection/element collection mapping for this type of descriptor.
    • newOneToOneMapping

      public ObjectReferenceMapping newOneToOneMapping()
      Return a new one to one mapping for this type of descriptor.
    • newManyToOneMapping

      public ObjectReferenceMapping newManyToOneMapping()
      Return a new many to one mapping for this type of descriptor.
    • newOneToManyMapping

      public CollectionMapping newOneToManyMapping()
      Return a new one to many mapping for this type of descriptor.
    • newUnidirectionalOneToManyMapping

      public CollectionMapping newUnidirectionalOneToManyMapping()
      Return a new one to many mapping for this type of descriptor.
    • newManyToManyMapping

      public CollectionMapping newManyToManyMapping()
      Return a new one to many mapping for this type of descriptor.
    • addDirectMapping

      public DatabaseMapping addDirectMapping(String attributeName, String fieldName)
      PUBLIC: Add a direct to field mapping to the receiver. The new mapping specifies that an instance variable of the class of objects which the receiver describes maps in the default manner for its type to the indicated database field.
      Parameters:
      attributeName - is the name of an instance variable of the class which the receiver describes.
      fieldName - is the name of the database column which corresponds with the designated instance variable.
      Returns:
      The newly created DatabaseMapping is returned.
    • addDirectMapping

      public DatabaseMapping addDirectMapping(String attributeName, String getMethodName, String setMethodName, String fieldName)
      PUBLIC: Add a direct to field mapping to the receiver. The new mapping specifies that a variable accessed by the get and set methods of the class of objects which the receiver describes maps in the default manner for its type to the indicated database field.
    • addDirectQueryKey

      public void addDirectQueryKey(String queryKeyName, String fieldName)
      PUBLIC: Add a query key to the descriptor. Query keys define Java aliases to database fields.
    • addForeignKeyFieldNameForMultipleTable

      public void addForeignKeyFieldNameForMultipleTable(String sourceForeignKeyFieldName, String targetPrimaryKeyFieldName) throws DescriptorException
      PUBLIC: This protocol can be used to associate multiple tables with foreign key information. Use this method to associate secondary tables to a primary table. Specify the source foreign key field to the target primary key field. The join criteria will be generated based on the fields provided. Unless the customary insert order is specified by the user (using setMultipleTableInsertOrder method) the (automatically generated) table insert order will ensure that insert into target table happens before insert into the source table (there may be a foreign key constraint in the database that requires target table to be inserted before the source table).
      Throws:
      DescriptorException
    • addForeignKeyFieldForMultipleTable

      public void addForeignKeyFieldForMultipleTable(DatabaseField sourceForeignKeyField, DatabaseField targetPrimaryKeyField) throws DescriptorException
      PUBLIC: This protocol can be used to associate multiple tables with foreign key information. Use this method to associate secondary tables to a primary table. Specify the source foreign key field to the target primary key field. The join criteria will be generated based on the fields provided.
      Throws:
      DescriptorException
    • addMapping

      public DatabaseMapping addMapping(DatabaseMapping mapping)
      PUBLIC: Add a database mapping to the receiver. Perform any required initialization of both the mapping and the receiving descriptor as a result of adding the new mapping.
    • validateMappingType

      protected void validateMappingType(DatabaseMapping mapping)
    • addPrimaryKeyFieldName

      public void addPrimaryKeyFieldName(String fieldName)
      PUBLIC: Specify the primary key field of the descriptors table. This should be called for each field that makes up the primary key of the table. If the descriptor has many tables, this must be the primary key in the first table, if the other tables have the same primary key nothing else is required, otherwise a primary key/foreign key field mapping must be provided for each of the other tables.
      See Also:
    • addPrimaryKeyField

      public void addPrimaryKeyField(DatabaseField field)
      ADVANCED: Specify the primary key field of the descriptors table. This should be called for each field that makes up the primary key of the table. This can be used for advanced field types, such as XML nodes, or to set the field type.
    • addQueryKey

      public void addQueryKey(QueryKey queryKey)
      PUBLIC: Add a query key to the descriptor. Query keys define Java aliases to database fields.
    • addTable

      public void addTable(DatabaseTable table)
      PUBLIC: Specify the table for the class of objects the receiver describes. This method is used if there is more than one table.
    • addTableName

      public void addTableName(String tableName)
      PUBLIC: Specify the table name for the class of objects the receiver describes. If the table has a qualifier it should be specified using the dot notation, (i.e. "userid.employee"). This method is used if there is more than one table.
    • addUnconvertedProperty

      public void addUnconvertedProperty(String propertyName, String propertyValue, String propertyType)
      PUBLIC: Add an unconverted property (to be initialiazed at runtime)
    • adjustMultipleTableInsertOrder

      public void adjustMultipleTableInsertOrder()
      INTERNAL: Adjust the order of the tables in the multipleTableInsertOrder Vector according to the FK relationship if one (or more) were previously specified. I.e. target of FK relationship should be inserted before source. If the multipleTableInsertOrder has been specified (presumably by the user) then do not change it.
    • alwaysConformResultsInUnitOfWork

      public void alwaysConformResultsInUnitOfWork()
      PUBLIC: Used to set the descriptor to always conform in any unit of work query.
    • alwaysRefreshCache

      public void alwaysRefreshCache()
      PUBLIC: This method is the equivalent of calling setShouldAlwaysRefreshCache(boolean) with an argument of true: it configures a ClassDescriptor to always refresh the cache if data is received from the database by any query.

      However, if a query hits the cache, data is not refreshed regardless of how this setting is configured. For example, by default, when a query for a single object based on its primary key is executed, OracleAS TopLink will first look in the cache for the object. If the object is in the cache, the cached object is returned and data is not refreshed. To avoid cache hits, use the disableCacheHits() method.

      Also note that the UnitOfWork will not refresh its registered objects.

      Use this property with caution because it can lead to poor performance and may refresh on queries when it is not desired. Normally, if you require fresh data, it is better to configure a query with ObjectLevelReadQuery.refreshIdentityMapResult(). To ensure that refreshes are only done when required, use this method in conjunction with onlyRefreshCacheIfNewerVersion().

      See Also:
    • alwaysRefreshCacheOnRemote

      public void alwaysRefreshCacheOnRemote()
      PUBLIC: This method is the equivalent of calling setShouldAlwaysRefreshCacheOnRemote(boolean) with an argument of true: it configures a ClassDescriptor to always remotely refresh the cache if data is received from the database by any query in a RemoteSession.

      However, if a query hits the cache, data is not refreshed regardless of how this setting is configured. For example, by default, when a query for a single object based on its primary key is executed, OracleAS TopLink will first look in the cache for the object. If the object is in the cache, the cached object is returned and data is not refreshed. To avoid cache hits, use the disableCacheHitsOnRemote() method.

      Also note that the UnitOfWork will not refresh its registered objects.

      Use this property with caution because it can lead to poor performance and may refresh on queries when it is not desired. Normally, if you require fresh data, it is better to configure a query with ObjectLevelReadQuery.refreshIdentityMapResult(). To ensure that refreshes are only done when required, use this method in conjunction with onlyRefreshCacheIfNewerVersion().

      See Also:
    • applyAmendmentMethod

      public void applyAmendmentMethod()
      ADVANCED: Call the descriptor amendment method. This is called while loading or creating a descriptor that has an amendment method defined.
    • applyAmendmentMethod

      public void applyAmendmentMethod(DescriptorEvent event)
      INTERNAL: Call the descriptor amendment method. This is called while loading or creating a descriptor that has an amendment method defined.
    • arePrimaryKeyFields

      public boolean arePrimaryKeyFields(Vector fields)
      INTERNAL: Used to determine if a foreign key references the primary key.
    • assignDefaultValues

      protected void assignDefaultValues(AbstractSession session)
      INTERNAL: Some attributes have default values defined in Project. If such the value for the attribute hasn't been set then the default value is assigned.
    • buildBatchCriteriaByPK

      public Expression buildBatchCriteriaByPK(ExpressionBuilder builder, ObjectLevelReadQuery query)
      INTERNAL: Return the selection criteria used to IN batch fetching.
    • buildCallFromStatement

      public DatasourceCall buildCallFromStatement(SQLStatement statement, DatabaseQuery query, AbstractSession session)
      INTERNAL: Return a call built from a statement. Subclasses may throw an exception if the statement is not appropriate.
    • buildDirectValuesFromFieldValue

      public Vector buildDirectValuesFromFieldValue(Object fieldValue) throws DatabaseException
      INTERNAL: Extract the direct values from the specified field value. Return them in a vector.
      Throws:
      DatabaseException
    • buildField

      public DatabaseField buildField(String fieldName)
      INTERNAL: A DatabaseField is built from the given field name.
    • buildField

      public DatabaseField buildField(DatabaseField field)
      INTERNAL: The table of the field is ensured to be unique from the descriptor's tables. If the field has no table the default table is assigned. This is used only in initialization. Fields are ensured to be unique so if the field has already been built it is returned.
    • buildField

      public DatabaseField buildField(DatabaseField field, DatabaseTable relationTable)
    • buildFieldValueFromDirectValues

      public Object buildFieldValueFromDirectValues(Vector directValues, String elementDataTypeName, AbstractSession session) throws DatabaseException
      INTERNAL: Build the appropriate field value for the specified set of direct values.
      Throws:
      DatabaseException
    • buildFieldValueFromForeignKeys

      public Object buildFieldValueFromForeignKeys(Vector foreignKeys, String referenceDataTypeName, AbstractSession session) throws DatabaseException
      INTERNAL: Build and return the appropriate field value for the specified set of foreign keys (i.e. each row has the fields that make up a foreign key).
      Throws:
      DatabaseException
    • buildFieldValueFromNestedRow

      public Object buildFieldValueFromNestedRow(AbstractRecord nestedRow, AbstractSession session) throws DatabaseException
      INTERNAL: Build and return the field value from the specified nested database row.
      Throws:
      DatabaseException
    • buildFieldValueFromNestedRows

      public Object buildFieldValueFromNestedRows(Vector nestedRows, String structureName, AbstractSession session) throws DatabaseException
      INTERNAL: Build and return the appropriate field value for the specified set of nested rows.
      Throws:
      DatabaseException
    • buildNestedRowFromFieldValue

      public AbstractRecord buildNestedRowFromFieldValue(Object fieldValue) throws DatabaseException
      INTERNAL: Build and return the nested database row from the specified field value.
      Throws:
      DatabaseException
    • buildNestedRowsFromFieldValue

      public Vector buildNestedRowsFromFieldValue(Object fieldValue, AbstractSession session) throws DatabaseException
      INTERNAL: Build and return the nested rows from the specified field value.
      Throws:
      DatabaseException
    • checkDatabase

      protected void checkDatabase(AbstractSession session)
      To check that tables and fields are present in database
    • checkInheritanceTreeAggregateSettings

      public void checkInheritanceTreeAggregateSettings(AbstractSession session, AggregateMapping mapping) throws DescriptorException
      INTERNAL: Verify that an aggregate descriptor's inheritance tree is full of aggregate descriptors.
      Throws:
      DescriptorException
    • createMultipleTableInsertOrder

      protected void createMultipleTableInsertOrder()
      INTERNAL: Create multiple table insert order. If its a child descriptor then insert order starts with the same insert order as in the parent. Non-inherited tables ordered to adhere to multipleTableForeignKeys: the target table (the key in multipleTableForeignKeys map) should stand in insert order before any of the source tables (members of the corresponding value in multipleTableForeignKeys).
    • verifyMultipleTableInsertOrder

      protected void verifyMultipleTableInsertOrder()
      INTERNAL: Verify multiple table insert order provided by the user. If its a child descriptor then insert order starts with the same insert order as in the parent. Non-inherited tables ordered to adhere to multipleTableForeignKeys: the target table (the key in multipleTableForeignKeys map) should stand in insert order before any of the source tables (members of the corresponding value in multipleTableForeignKeys).
    • verifyMultipleTablesForeignKeysTables

      protected void verifyMultipleTablesForeignKeysTables()
      INTERNAL: Verify that the tables specified in multipleTablesForeignKeysTables are valid.
    • createTableComparison

      protected int[][] createTableComparison(List<DatabaseTable> tables, int nStart)
      INTERNAL: This helper method creates a matrix that contains insertion order comparison for the tables. Comparison is done for indexes from nStart to tables.size()-1.
    • createMultipleTableInsertOrderFromComparison

      protected void createMultipleTableInsertOrderFromComparison(int[][] tableComparison, int nStart)
      INTERNAL: This helper method creates multipleTableInsertOrderFromComparison using comparison matrix created by createTableComparison(getTables()) method call.
    • createTableOrder

      protected boolean createTableOrder(int k, int nTables, int[] tableOrder, int[][] tableComparison)
      INTERNAL: This helper method recursively puts indexes from 0 to nTables-1 into tableOrder according to tableComparison 2 dim array. k is index in tableOrder that currently the method is working on - the method should be called with k = 0.
    • clone

      public Object clone()
      INTERNAL: Clones the descriptor
      Overrides:
      clone in class Object
    • convertClassNamesToClasses

      public void convertClassNamesToClasses(ClassLoader classLoader)
      INTERNAL: Convert all the class-name-based settings in this Descriptor 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.
    • createCopyPolicy

      public void createCopyPolicy(String policyType)
      PUBLIC: Create a copy policy of the type passed in as a string.
    • createInstantiationPolicy

      public void createInstantiationPolicy(String policyType)
      PUBLIC: Create a instantiation policy of the type passed in as a string.
    • descriptorIsAggregate

      public void descriptorIsAggregate()
      PUBLIC: Sets the descriptor to be an aggregate. An aggregate descriptor is contained within another descriptor's table. Aggregate descriptors are insert/updated/deleted with their owner and cannot exist without their owner as they share the same row. Aggregates are not cached (they are cached as part of their owner) and cannot be read/written/deleted/registered. All aggregate descriptors must call this.
    • descriptorIsAggregateCollection

      public void descriptorIsAggregateCollection()
      PUBLIC: Sets the descriptor to be part of an aggregate collection. An aggregate collection descriptor stored in a separate table but some of the fields (the primary key) comes from its owner. Aggregate collection descriptors are insert/updated/deleted with their owner and cannot exist without their owner as they share the primary key. Aggregate collections are not cached (they are cached as part of their owner) and cannot be read/written/deleted/registered. All aggregate collection descriptors must call this.
    • descriptorIsForInterface

      public void descriptorIsForInterface()
      PUBLIC: Sets the descriptor to be for an interface. An interface descriptor allows for other classes to reference an interface or one of several other classes. The implementor classes can be completely unrelated in term of the database stored in distinct tables. Queries can also be done for the interface which will query each of the implementor classes. An interface descriptor cannot define any mappings as an interface is just API and not state, a interface descriptor should define the common query key of its implementors to allow querying. An interface descriptor also does not define a primary key or table or other settings. If an interface only has a single implementor (i.e. a classes public interface or remote) then an interface descriptor should not be defined for it and relationships should be to the implementor class not the interface, in this case the implementor class can add the interface through its interface policy to map queries on the interface to it.
    • descriptorIsNormal

      public void descriptorIsNormal()
      PUBLIC: Sets the descriptor to be normal. This is the default and means the descriptor is not aggregate or for an interface.
    • disableCacheHits

      public void disableCacheHits()
      PUBLIC: Allow for cache hits on primary key read object queries to be disabled. This can be used with alwaysRefreshCache() or alwaysRefreshCacheOnRemote() to ensure queries always go to the database.
    • disableCacheHitsOnRemote

      public void disableCacheHitsOnRemote()
      PUBLIC: Allow for remote session cache hits on primary key read object queries to be disabled. This can be used with alwaysRefreshCacheOnRemote() to ensure queries always go to the server session cache.
      See Also:
    • dontAlwaysConformResultsInUnitOfWork

      public void dontAlwaysConformResultsInUnitOfWork()
      PUBLIC: The descriptor is defined to not conform the results in unit of work in read query. Default.
    • dontAlwaysRefreshCache

      public void dontAlwaysRefreshCache()
      PUBLIC: This method is the equivalent of calling setShouldAlwaysRefreshCache(boolean) with an argument of false: it ensures that a ClassDescriptor is not configured to always refresh the cache if data is received from the database by any query.
      See Also:
    • dontAlwaysRefreshCacheOnRemote

      public void dontAlwaysRefreshCacheOnRemote()
      PUBLIC: This method is the equivalent of calling setShouldAlwaysRefreshCacheOnRemote(boolean) with an argument of false: it ensures that a ClassDescriptor is not configured to always remotely refresh the cache if data is received from the database by any query in a RemoteSession.
      See Also:
    • dontDisableCacheHits

      public void dontDisableCacheHits()
      PUBLIC: Allow for cache hits on primary key read object queries.
      See Also:
    • dontDisableCacheHitsOnRemote

      public void dontDisableCacheHitsOnRemote()
      PUBLIC: Allow for remote session cache hits on primary key read object queries.
      See Also:
    • dontOnlyRefreshCacheIfNewerVersion

      public void dontOnlyRefreshCacheIfNewerVersion()
      PUBLIC: This method is the equivalent of calling setShouldOnlyRefreshCacheIfNewerVersion(boolean) with an argument of false: it ensures that a ClassDescriptor is not configured to only refresh the cache if the data received from the database by a query is newer than the data in the cache (as determined by the optimistic locking field).
      See Also:
    • extractDefaultTable

      protected DatabaseTable extractDefaultTable()
      INTERNAL: The first table in the tables is always treated as default.
    • getAdditionalAggregateCollectionKeyFields

      public List<DatabaseField> getAdditionalAggregateCollectionKeyFields()
      INTERNAL: additionalAggregateCollectionKeyFields are used by aggregate descriptors to hold additional fields needed when they are stored in an AggregatateCollection These fields are generally foreign key fields that are required in addition to the fields in the descriptor's mappings to uniquely identify the Aggregate
    • getAdditionalTablePrimaryKeyFields

      public Map<DatabaseTable,Map<DatabaseField,DatabaseField>> getAdditionalTablePrimaryKeyFields()
      INTERNAL: This is used to map the primary key field names in a multiple table descriptor.
    • getAdditionalWritableMapKeyFields

      public List<DatabaseField> getAdditionalWritableMapKeyFields()
      INTERNAL: Return a list of fields that are written by map keys Used to determine if there is a multiple writable mappings issue
    • getAlias

      public String getAlias()
      PUBLIC: Get the alias
    • getAllFields

      public Vector<DatabaseField> getAllFields()
      INTERNAL: Return all the fields which include all child class fields. By default it is initialized to the fields for the current descriptor.
    • getAllSelectionFields

      public List<DatabaseField> getAllSelectionFields()
      INTERNAL: Return all selection fields which include all child class fields. By default it is initialized to selection fields for the current descriptor.
    • getAllSelectionFields

      public List<DatabaseField> getAllSelectionFields(ObjectLevelReadQuery query)
      INTERNAL: Return all selection fields which include all child class fields. By default it is initialized to selection fields for the current descriptor.
    • getReturnFieldsToGenerateInsert

      public Vector<DatabaseField> getReturnFieldsToGenerateInsert()
      INTERNAL: Return fields used to build insert statement.
    • getReturnFieldsToGenerateUpdate

      public Vector<DatabaseField> getReturnFieldsToGenerateUpdate()
      INTERNAL: Return fields used to build update statement.
    • getReturnFieldsToMergeInsert

      public List<DatabaseField> getReturnFieldsToMergeInsert()
      INTERNAL: Return fields used in to map into entity for insert.
    • getReturnFieldsToMergeUpdate

      public List<DatabaseField> getReturnFieldsToMergeUpdate()
      INTERNAL: Return fields used in to map into entity for update.
    • getAmendmentClass

      public Class<?> getAmendmentClass()
      PUBLIC: Return the amendment class. The amendment method will be called on the class before initialization to allow for it to initialize the descriptor. The method must be a public static method on the class.
    • getAmendmentClassName

      public String getAmendmentClassName()
      INTERNAL: Return amendment class name, used by the MW.
    • getAmendmentMethodName

      public String getAmendmentMethodName()
      PUBLIC: Return the amendment method. This will be called on the amendment class before initialization to allow for it to initialize the descriptor. The method must be a public static method on the class.
    • getAccessorTree

      public List<AttributeAccessor> getAccessorTree()
      Returns:
      the accessorTree
    • getObjectChangePolicy

      public ObjectChangePolicy getObjectChangePolicy()
      PUBLIC: Return this objects ObjectChangePolicy.
    • getObjectChangePolicyInternal

      public ObjectChangePolicy getObjectChangePolicyInternal()
      INTERNAL: Return this objects ObjectChangePolicy and do not lazy initialize
    • getHistoryPolicy

      public HistoryPolicy getHistoryPolicy()
      PUBLIC: Return this descriptor's HistoryPolicy.
    • getPartitioningPolicy

      public PartitioningPolicy getPartitioningPolicy()
      PUBLIC: Return the descriptor's partitioning policy.
    • setPartitioningPolicy

      public void setPartitioningPolicy(PartitioningPolicy partitioningPolicy)
      PUBLIC: Set the descriptor's partitioning policy. A PartitioningPolicy is used to partition the data for a class across multiple difference databases or across a database cluster such as Oracle RAC. Partitioning can provide improved scalability by allowing multiple database machines to service requests.
    • getPartitioningPolicyName

      public String getPartitioningPolicyName()
      PUBLIC: Return the name of the descriptor's partitioning policy. A PartitioningPolicy with the same name must be defined on the Project. A PartitioningPolicy is used to partition the data for a class across multiple difference databases or across a database cluster such as Oracle RAC. Partitioning can provide improved scalability by allowing multiple database machines to service requests.
    • setPartitioningPolicyName

      public void setPartitioningPolicyName(String partitioningPolicyName)
      PUBLIC: Set the name of the descriptor's partitioning policy. A PartitioningPolicy with the same name must be defined on the Project. A PartitioningPolicy is used to partition the data for a class across multiple difference databases or across a database cluster such as Oracle RAC. Partitioning can provide improved scalability by allowing multiple database machines to service requests.
    • getCacheInterceptorClass

      public Class<? extends CacheInterceptor> getCacheInterceptorClass()
      A CacheInterceptor is an adaptor that when overridden and assigned to a Descriptor all interaction between EclipseLink and the internal cache for that class will pass through the Interceptor. Advanced users could use this interceptor to audit, profile or log cache access. This Interceptor could also be used to redirect or augment the TopLink cache with an alternate cache mechanism. EclipseLink's configurated IdentityMaps will be passed to the Interceptor constructor. As with IdentityMaps an entire class inheritance hierarchy will share the same interceptor.
      See Also:
    • getCacheInterceptorClassName

      public String getCacheInterceptorClassName()
      A CacheInterceptor is an adaptor that when overridden and assigned to a Descriptor all interaction between EclipseLink and the internal cache for that class will pass through the Interceptor. Advanced users could use this interceptor to audit, profile or log cache access. This Interceptor could also be used to redirect or augment the TopLink cache with an alternate cache mechanism. EclipseLink's configurated IdentityMaps will be passed to the Interceptor constructor. As with IdentityMaps an entire class inheritance hierarchy will share the same interceptor.
      See Also:
    • getCacheInvalidationPolicy

      public CacheInvalidationPolicy getCacheInvalidationPolicy()
      PUBLIC: Return the CacheInvalidationPolicy for this descriptor For uninitialized cache invalidation policies, this will return a NoExpiryCacheInvalidationPolicy
      Returns:
      CacheInvalidationPolicy
      See Also:
    • getCacheSynchronizationType

      public int getCacheSynchronizationType()
      PUBLIC: Get a value indicating the type of cache synchronization that will be used on objects of this type. Possible values are: SEND_OBJECT_CHANGES INVALIDATE_CHANGED_OBJECTS SEND_NEW_OBJECTS+WITH_CHANGES DO_NOT_SEND_CHANGES
    • getCascadeLockingPolicies

      public List<CascadeLockingPolicy> getCascadeLockingPolicies()
      INTERNAL:
    • getConstraintDependencies

      public Vector getConstraintDependencies()
      ADVANCED: automatically orders database access through the foreign key information provided in 1:1 and 1:m mappings. In some case when 1:1 are not defined it may be required to tell the descriptor about a constraint, this defines that this descriptor has a foreign key constraint to another class and must be inserted after instances of the other class.
    • getCopyPolicy

      public CopyPolicy getCopyPolicy()
      INTERNAL: Returns the copy policy.
    • getCopyPolicyClassName

      public String getCopyPolicyClassName()
      INTERNAL: Returns the name of a Class that implements CopyPolicy Will be instantiated as a copy policy at initialization times using the no-args constructor
    • getDefaultTable

      public DatabaseTable getDefaultTable()
      INTERNAL: The first table in the tables is always treated as default.
    • getDescriptorType

      public int getDescriptorType()
      ADVANCED: return the descriptor type (NORMAL by default, others include INTERFACE, AGGREGATE, AGGREGATE COLLECTION)
    • getDescriptorTypeValue

      public String getDescriptorTypeValue()
      INTERNAL: This method is explicitly used by the XML reader.
    • getDerivesIdMappinps

      public Collection<DatabaseMapping> getDerivesIdMappinps()
      ADVANCED: Return the derives id mappings.
    • getDescriptorCustomizerClassName

      public String getDescriptorCustomizerClassName()
      INTERNAL: DescriptorCustomizer is the JPA equivalent of an amendment method.
    • getDescriptorEventManager

      public DescriptorEventManager getDescriptorEventManager()
      PUBLIC: Get the event manager for the descriptor. The event manager is responsible for managing the pre/post selectors.
    • getEventManager

      public DescriptorEventManager getEventManager()
      PUBLIC: Get the event manager for the descriptor. The event manager is responsible for managing the pre/post selectors.
      Specified by:
      getEventManager in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
    • getFields

      public Vector<DatabaseField> getFields()
      INTERNAL: Return all the fields
    • getSelectionFields

      public List<DatabaseField> getSelectionFields()
      INTERNAL: Return all selection fields
    • getSelectionFields

      public List<DatabaseField> getSelectionFields(ObjectLevelReadQuery query)
      INTERNAL: Return all selection fields
    • getForeignKeyValuesForCaching

      public Set<DatabaseField> getForeignKeyValuesForCaching()
      INTERNAL:
    • getIdentityMapClass

      public <T extends IdentityMap> Class<T> getIdentityMapClass()
      INTERNAL: Return the class of identity map to be used by this descriptor. The default is the "SoftCacheWeakIdentityMap".
    • getIdentityMapSize

      public int getIdentityMapSize()
      PUBLIC: Return the size of the identity map.
    • getDescriptorInheritancePolicy

      public InheritancePolicy getDescriptorInheritancePolicy()
      PUBLIC: The inheritance policy is used to define how a descriptor takes part in inheritance. All inheritance properties for both child and parent classes is configured in inheritance policy. Caution must be used in using this method as it lazy initializes an inheritance policy. Calling this on a descriptor that does not use inheritance will cause problems, #hasInheritance() must always first be called.
    • getInheritancePolicy

      public InheritancePolicy getInheritancePolicy()
      PUBLIC: The inheritance policy is used to define how a descriptor takes part in inheritance. All inheritance properties for both child and parent classes is configured in inheritance policy. Caution must be used in using this method as it lazy initializes an inheritance policy. Calling this on a descriptor that does not use inheritance will cause problems, #hasInheritance() must always first be called.
      Specified by:
      getInheritancePolicy in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
    • getInheritancePolicyOrNull

      public InheritancePolicy getInheritancePolicyOrNull()
      INTERNAL: Return the inheritance policy.
    • getInstantiationPolicy

      public InstantiationPolicy getInstantiationPolicy()
      INTERNAL: Returns the instantiation policy.
      Specified by:
      getInstantiationPolicy in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
    • getInterfacePolicy

      public InterfacePolicy getInterfacePolicy()
      PUBLIC: Returns the InterfacePolicy. The interface policy allows for a descriptor's public and variable interfaces to be defined. Caution must be used in using this method as it lazy initializes an interface policy. Calling this on a descriptor that does not use interfaces will cause problems, #hasInterfacePolicy() must always first be called.
    • getInterfacePolicyOrNull

      public InterfacePolicy getInterfacePolicyOrNull()
      INTERNAL: Returns the InterfacePolicy.
    • getJavaClass

      public <T> Class<T> getJavaClass()
      PUBLIC: Return the java class.
      Specified by:
      getJavaClass in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
    • getJavaClassName

      public String getJavaClassName()
      Return the class name, used by the MW.
    • getLockableMappings

      public List<DatabaseMapping> getLockableMappings()
      INTERNAL: Returns a reference to the mappings that must be traverse when locking
    • getMappingForAttributeName

      public DatabaseMapping getMappingForAttributeName(String attributeName)
      PUBLIC: Returns the mapping associated with a given attribute name. This can be used to find a descriptors mapping in a amendment method before the descriptor has been initialized.
    • removeMappingForAttributeName

      public DatabaseMapping removeMappingForAttributeName(String attributeName)
      ADVANCED: Removes the locally defined mapping associated with a given attribute name. This can be used in a amendment method before the descriptor has been initialized.
    • getMappings

      public Vector<DatabaseMapping> getMappings()
      PUBLIC: Returns mappings
    • getMultipleTableForeignKeyAssociations

      public Vector getMultipleTableForeignKeyAssociations()
      INTERNAL: Returns the foreign key relationships used for multiple tables which were specified by the user. Used by the Project XML writer to output these associations
      See Also:
    • getMultipleTableForeignKeys

      public Map<DatabaseTable,Set<DatabaseTable>> getMultipleTableForeignKeys()
      INTERNAL: Returns the foreign key relationships used for multiple tables which were specified by the user. The key of the Map is the field in the source table of the foreign key relationship. The value is the field name of the target table.
      See Also:
    • getMultipleTableInsertOrder

      public List<DatabaseTable> getMultipleTableInsertOrder() throws DescriptorException
      INTERNAL: Returns the List of DatabaseTables in the order which INSERTS should take place. This order is determined by the foreign key fields which are specified by the user.
      Throws:
      DescriptorException
    • getMultipleTablePrimaryKeyAssociations

      public Vector getMultipleTablePrimaryKeyAssociations()
      INTERNAL: Returns the foreign key relationships used for multiple tables which were specified by the user. Used by the Project XML writer to output these associations
      See Also:
    • getMultitenantPolicy

      public MultitenantPolicy getMultitenantPolicy()
      INTERNAL: Retun the multitenant policy
    • getObjectBuilder

      public ObjectBuilder getObjectBuilder()
      INTERNAL: Return the object builder
      Specified by:
      getObjectBuilder in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
    • getOptimisticLockingPolicy

      public OptimisticLockingPolicy getOptimisticLockingPolicy()
      PUBLIC: Returns the OptimisticLockingPolicy. By default this is an instance of VersionLockingPolicy.
    • getPreDeleteMappings

      public List<DatabaseMapping> getPreDeleteMappings()
      INTERNAL: Set of mappings that require early delete behavior. This is used to handle deletion constraints.
    • addPreDeleteMapping

      public void addPreDeleteMapping(DatabaseMapping mapping)
      INTERNAL: Add the mapping to be notified before deletion. Must also be added to child descriptors.
    • getPrimaryKeyFieldNames

      public Vector<String> getPrimaryKeyFieldNames()
      PUBLIC: Return the names of all the primary keys.
      Specified by:
      getPrimaryKeyFieldNames in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
    • getPrimaryKeyFields

      public List<DatabaseField> getPrimaryKeyFields()
      INTERNAL: Return all the primary key fields
      Specified by:
      getPrimaryKeyFields in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
    • getProperties

      public Map getProperties()
      PUBLIC: Returns the user defined properties.
    • getProperty

      public Object getProperty(String name)
      PUBLIC: Returns the descriptor property associated the given String.
    • getQueryKeyNamed

      public QueryKey getQueryKeyNamed(String queryKeyName)
      INTERNAL: Return the query key with the specified name
    • getQueryKeys

      public Map<String,QueryKey> getQueryKeys()
      PUBLIC: Return the query keys.
    • getDescriptorQueryManager

      public DescriptorQueryManager getDescriptorQueryManager()
      PUBLIC: Return the queryManager. The query manager can be used to specify customization of the SQL that generates for this descriptor.
    • getQueryManager

      public DescriptorQueryManager getQueryManager()
      PUBLIC: Return the queryManager. The query manager can be used to specify customization of the SQL that generates for this descriptor.
    • getRemoteIdentityMapClass

      public <T extends IdentityMap> Class<T> getRemoteIdentityMapClass()
      INTERNAL: Return the class of identity map to be used by this descriptor. The default is the "SoftCacheWeakIdentityMap".
    • getRootDescriptor

      public ClassDescriptor getRootDescriptor()
      PUBLIC: This method returns the root descriptor for for this descriptor's class heirarchy. If the user is not using inheritance then the root class will be this class.
    • getRemoteIdentityMapSize

      public int getRemoteIdentityMapSize()
      PUBLIC: Return the size of the remote identity map.
    • getReturningPolicy

      public ReturningPolicy getReturningPolicy()
      PUBLIC: Return returning policy.
    • getReturningPolicies

      public List<ReturningPolicy> getReturningPolicies()
      PUBLIC: Return returning policy from current descriptor and from mappings
    • getSequenceNumberField

      public DatabaseField getSequenceNumberField()
      INTERNAL: Get sequence number field
    • getSequenceNumberFieldName

      public String getSequenceNumberFieldName()
      PUBLIC: Get sequence number field name
    • getSequenceNumberName

      public String getSequenceNumberName()
      PUBLIC: Get sequence number name
    • getSessionName

      public String getSessionName()
      INTERNAL: Return the name of the session local to this descriptor. This is used by the session broker.
    • getTable

      public DatabaseTable getTable(String tableName) throws DescriptorException
      INTERNAL: Checks if table name exists with the current descriptor or not.
      Throws:
      DescriptorException
    • getTableName

      public String getTableName()
      PUBLIC: Return the name of the descriptor's first table. This method must only be called on single table descriptors.
    • getTableNames

      public Vector getTableNames()
      PUBLIC: Return the table names.
    • getTablePerClassPolicy

      public TablePerClassPolicy getTablePerClassPolicy()
      PUBLIC: Returns the TablePerClassPolicy. The table per class policy allows JPA users to configure the TABLE_PER_CLASS inheritance strategy. Calling this on a descriptor that does not use table per class will cause problems, #hasTablePerClassPolicy() must always first be called.
      See Also:
    • getTables

      public Vector<DatabaseTable> getTables()
      INTERNAL: Return all the tables.
    • getTypedField

      public DatabaseField getTypedField(DatabaseField field)
      INTERNAL: searches first descriptor than its ReturningPolicy for an equal field
      Specified by:
      getTypedField in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
    • getWrapperPolicy

      public WrapperPolicy getWrapperPolicy()
      ADVANCED: Return the WrapperPolicy for this descriptor. This advanced feature can be used to wrap objects with other classes such as CORBA TIE objects or EJBs.
    • hasDependencyOnParts

      public boolean hasDependencyOnParts()
      INTERNAL: Checks if the class has any private owned parts or other dependencies, (i.e. M:M join table).
    • hasDerivedId

      public boolean hasDerivedId()
      INTERNAL: returns true if users have designated one or more mappings as IDs. Used for CMP3Policy primary key class processing.
    • hasEventManager

      public boolean hasEventManager()
      INTERNAL: returns true if a DescriptorEventManager has been set.
      Specified by:
      hasEventManager in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
    • hasInheritance

      public boolean hasInheritance()
      INTERNAL: Return if this descriptor is involved in inheritance, (is child or parent). Note: If this class is part of table per class inheritance strategy this method will return false.
      Specified by:
      hasInheritance in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
      See Also:
    • hasInterfacePolicy

      public boolean hasInterfacePolicy()
      INTERNAL: Return if this descriptor is involved in interface, (is child or parent).
    • hasMultipleTables

      public boolean hasMultipleTables()
      INTERNAL: Check if descriptor has multiple tables
    • hasNestedIdentityReference

      public boolean hasNestedIdentityReference(boolean withChildren)
      INTERNAL: Calculates whether descriptor references an entity (directly or through a nested mapping).
    • hasNoncacheableMappings

      public boolean hasNoncacheableMappings()
      Returns:
      the hasNoncacheableMappings
    • hasPreDeleteMappings

      public boolean hasPreDeleteMappings()
      Returns:
      the preDeleteMappings
    • hasPrivatelyOwnedParts

      public boolean hasPrivatelyOwnedParts()
      INTERNAL: Checks if the class has any private owned parts are not
    • hasQueryKeyOrMapping

      public boolean hasQueryKeyOrMapping(String attributeName)
      INTERNAL: Checks to see if it has a query key or mapping with the specified name or not.
    • hasRelationships

      public boolean hasRelationships()
      INTERNAL: return whether this descriptor has any relationships through its mappings, through inheritance, or through aggregates
    • hasRelationshipsExceptBackpointer

      public boolean hasRelationshipsExceptBackpointer(ClassDescriptor descriptor)
      INTERNAL: This method returns true if this descriptor has either a ForeignReferenceMapping to an object aside from the one described by descriptor or more than one ForeignReferenceMapping to descriptor. (i.e. It determines if there is any mapping aside from a backpointer to a mapping defined in descriptor)
    • hasReturningPolicy

      public boolean hasReturningPolicy()
      INTERNAL: Return if this descriptor has Returning policy.
    • hasReturningPolicies

      public boolean hasReturningPolicies()
      INTERNAL: Return if this descriptor or descriptors from mappings has Returning policy.
    • hasSerializedObjectPolicy

      public boolean hasSerializedObjectPolicy()
      INTERNAL:
    • getSerializedObjectPolicy

      public SerializedObjectPolicy getSerializedObjectPolicy()
      INTERNAL:
    • setSerializedObjectPolicy

      public void setSerializedObjectPolicy(SerializedObjectPolicy serializedObjectPolicy)
      INTERNAL:
    • hasWrapperPolicy

      public boolean hasWrapperPolicy()
      INTERNAL: Return if a wrapper policy is used.
    • initialize

      public void initialize(AbstractSession session) throws DescriptorException
      INTERNAL: Initialize the mappings as a separate step. This is done as a separate step to ensure that inheritance has been first resolved.
      Throws:
      DescriptorException
    • initialize

      public void initialize(DescriptorQueryManager queryManager, AbstractSession session)
      INTERNAL: Initialize the query manager specific to the descriptor type.
    • initializeAggregateInheritancePolicy

      public void initializeAggregateInheritancePolicy(AbstractSession session)
      INTERNAL: This initialized method is used exclusively for inheritance. It passes in true if the child descriptor is isolated. This is needed by regular aggregate descriptors (because they require review); but not by SDK aggregate descriptors.
    • initializeMultipleTablePrimaryKeyFields

      public void initializeMultipleTablePrimaryKeyFields()
      INTERNAL: Rebuild the multiple table primary key map.
    • initializeProperties

      protected void initializeProperties(AbstractSession session) throws DescriptorException
      INTERNAL: Initialize the descriptor properties such as write lock and sequencing.
      Throws:
      DescriptorException
    • interfaceInitialization

      public void interfaceInitialization(AbstractSession session) throws DescriptorException
      INTERNAL: Allow the descriptor to initialize any dependencies on this session.
      Throws:
      DescriptorException
    • isAbstract

      public boolean isAbstract()
      INTERNAL: Convenience method to return true if the java class from this descriptor is abstract.
    • isAggregateCollectionDescriptor

      public boolean isAggregateCollectionDescriptor()
      PUBLIC: Return true if this descriptor is an aggregate collection descriptor
    • isAggregateDescriptor

      public boolean isAggregateDescriptor()
      PUBLIC: Return true if this descriptor is an aggregate descriptor
    • isChildDescriptor

      public boolean isChildDescriptor()
      PUBLIC: Return if the descriptor defines inheritance and is a child.
    • isEISDescriptor

      public boolean isEISDescriptor()
      PUBLIC: Return if the descriptor maps to an EIS or NoSQL datasource.
    • isObjectRelationalDataTypeDescriptor

      public boolean isObjectRelationalDataTypeDescriptor()
      PUBLIC: Return if the descriptor maps to an object-relational structured type.
    • isXMLDescriptor

      public boolean isXMLDescriptor()
      PUBLIC: Return if the descriptor maps to XML.
    • isRelationalDescriptor

      public boolean isRelationalDescriptor()
      PUBLIC: Return if the descriptor maps to a relational table.
    • isDescriptorForInterface

      public boolean isDescriptorForInterface()
      PUBLIC: Return if the java class is an interface.
    • isDescriptorTypeAggregate

      public boolean isDescriptorTypeAggregate()
      PUBLIC return true if this descriptor is any type of aggregate descriptor.
    • isDescriptorTypeNormal

      public boolean isDescriptorTypeNormal()
      INTERNAL: return true if this descriptor is an entity. (The descriptor may be a mappedSuperclass - only in the internal case during metamodel processing)
    • isFullyInitialized

      public boolean isFullyInitialized()
      INTERNAL: Check if the descriptor is finished initialization.
    • isInitialized

      protected boolean isInitialized(int initializationStage)
      INTERNAL: Check if descriptor is already initialized for the level of initialization. 1 = pre 2 = mapping 3 = post
    • isInterfaceChildDescriptor

      public boolean isInterfaceChildDescriptor()
      INTERNAL: Return if the descriptor defines inheritance and is a child.
    • isInterfaceInitialized

      protected boolean isInterfaceInitialized(int interfaceInitializationStage)
      INTERNAL: Check if interface descriptor is already initialized for the level of initialization. 1 = pre 2 = mapping 3 = post
    • isInvalid

      public boolean isInvalid()
      INTERNAL: Return if an error occurred during initialization which should abort any further initialization.
    • isIsolated

      public boolean isIsolated()
      PUBLIC: Returns true if the descriptor represents an isolated class
    • isProtectedIsolation

      public boolean isProtectedIsolation()
      PUBLIC: Returns true if the descriptor represents an isolated class
    • isSharedIsolation

      public boolean isSharedIsolation()
      PUBLIC: Returns true if the descriptor represents an isolated class
    • isMultipleTableDescriptor

      public boolean isMultipleTableDescriptor()
      INTERNAL: Return if this descriptor has more than one table.
    • isPrimaryKeySetAfterInsert

      public boolean isPrimaryKeySetAfterInsert(AbstractSession session)
      INTERNAL: Indicates whether pk or some of its components set after insert into the database. Shouldn't be called before ClassDescriptor has been initialized.
    • shouldLockForClone

      public boolean shouldLockForClone()
      ADVANCED: When set to false, this setting will allow the UOW to avoid locking the shared cache instance in order to perform a clone. Caution should be taken as setting this to false may allow cloning of partial updates
    • shouldUseFullChangeSetsForNewObjects

      public boolean shouldUseFullChangeSetsForNewObjects()
      INTERNAL: Return if change sets are required for new objects.
    • onlyRefreshCacheIfNewerVersion

      public void onlyRefreshCacheIfNewerVersion()
      PUBLIC: This method is the equivalent of calling setShouldOnlyRefreshCacheIfNewerVersion(boolean) with an argument of true: it configures a ClassDescriptor to only refresh the cache if the data received from the database by a query is newer than the data in the cache (as determined by the optimistic locking field) and as long as one of the following is true:

      However, if a query hits the cache, data is not refreshed regardless of how this setting is configured. For example, by default, when a query for a single object based on its primary key is executed, EclipseLink will first look in the cache for the object. If the object is in the cache, the cached object is returned and data is not refreshed. To avoid cache hits, use the disableCacheHits() method.

      Also note that the UnitOfWork will not refresh its registered objects.

      See Also:
    • postInitialize

      public void postInitialize(AbstractSession session) throws DescriptorException
      INTERNAL: Post initializations after mappings are initialized.
      Throws:
      DescriptorException
    • notifyReferencingDescriptorsOfIsolation

      public void notifyReferencingDescriptorsOfIsolation(AbstractSession session)
      INTERNAL: Configure all descriptors referencing this class to be protected and update their cache settings.
    • preInitialize

      public void preInitialize(AbstractSession session) throws DescriptorException
      INTERNAL: Allow the descriptor to initialize any dependencies on this session.
      Throws:
      DescriptorException
    • prepareCascadeLockingPolicy

      protected void prepareCascadeLockingPolicy(DatabaseMapping mapping)
      INTERNAL:
    • preInitializeInheritancePolicy

      protected void preInitializeInheritancePolicy(AbstractSession session) throws DescriptorException
      Hook together the inheritance policy tree.
      Throws:
      DescriptorException
    • preInterfaceInitialization

      public void preInterfaceInitialization(AbstractSession session) throws DescriptorException
      INTERNAL: Allow the descriptor to initialize any dependencies on this session.
      Throws:
      DescriptorException
    • rehashFieldDependancies

      public void rehashFieldDependancies(AbstractSession session)
      INTERNAL: Rehash any hashtables based on fields. This is used to clone descriptors for aggregates, which hammer field names, it is probably better not to hammer the field name and this should be refactored.
    • reInitializeJoinedAttributes

      public void reInitializeJoinedAttributes()
      INTERNAL: A user should not be setting which attributes to join or not to join after descriptor initialization; provided only for backwards compatibility.
    • remoteInitialization

      public void remoteInitialization(DistributedSession session)
      INTERNAL: Used to initialize a remote descriptor.
    • removeProperty

      public void removeProperty(String property)
      PUBLIC: Remove the user defined property.
    • requiresInitialization

      public boolean requiresInitialization(AbstractSession session)
      INTERNAL: Aggregate and Interface descriptors do not require initialization as they are cloned and initialized by each mapping. Descriptors with table per tenant policies are cloned per client session (per tenant) so do not initialize the original descriptor.
    • selfValidationAfterInitialization

      protected void selfValidationAfterInitialization(AbstractSession session) throws DescriptorException
      INTERNAL: Validate that the descriptor was defined correctly. This allows for checks to be done that require the descriptor initialization to be completed.
      Throws:
      DescriptorException
    • selfValidationBeforeInitialization

      protected void selfValidationBeforeInitialization(AbstractSession session) throws DescriptorException
      INTERNAL: Validate that the descriptor's non-mapping attribute are defined correctly.
      Throws:
      DescriptorException
    • setAdditionalTablePrimaryKeyFields

      protected void setAdditionalTablePrimaryKeyFields(DatabaseTable table, DatabaseField field1, DatabaseField field2)
      INTERNAL: This is used to map the primary key field names in a multiple table descriptor.
    • toggleAdditionalTablePrimaryKeyFields

      protected void toggleAdditionalTablePrimaryKeyFields()
      INTERNAL: Eclipselink needs additionalTablePKFields entries to be associated with tables other than the main (getTables.get(0)) one. Also in case of two non-main tables additionalTablePKFields entry should be associated with the one father down insert order.
    • setAdditionalTablePrimaryKeyFields

      public void setAdditionalTablePrimaryKeyFields(Map<DatabaseTable,Map<DatabaseField,DatabaseField>> additionalTablePrimaryKeyFields)
      INTERNAL: This is used to map the primary key field names in a multiple table descriptor.
    • setAlias

      public void setAlias(String alias)
      PUBLIC: Set the alias
    • setAllFields

      protected void setAllFields(Vector<DatabaseField> allFields)
      INTERNAL: Set all the fields.
    • setAmendmentClass

      public void setAmendmentClass(Class<?> amendmentClass)
      PUBLIC: Set the amendment class. The amendment method will be called on the class before initialization to allow for it to initialize the descriptor. The method must be a public static method on the class.
    • setAmendmentClassName

      public void setAmendmentClassName(String amendmentClassName)
      INTERNAL: Return the amendment class name, used by the MW.
    • setAmendmentMethodName

      public void setAmendmentMethodName(String amendmentMethodName)
      PUBLIC: Set the amendment method. This will be called on the amendment class before initialization to allow for it to initialize the descriptor. The method must be a public static method on the class.
    • setAccessorTree

      public void setAccessorTree(List<AttributeAccessor> accessorTree)
      Parameters:
      accessorTree - the accessorTree to set
    • setCacheSynchronizationType

      public void setCacheSynchronizationType(int type)
      PUBLIC: Set the type of cache synchronization that will be used on objects of this type. Possible values are: SEND_OBJECT_CHANGES INVALIDATE_CHANGED_OBJECTS SEND_NEW_OBJECTS_WITH_CHANGES DO_NOT_SEND_CHANGES Note: Cache Synchronization type cannot be altered for descriptors that are set as isolated using the setIsIsolated method.
      Parameters:
      type - int The synchronization type for this descriptor
    • setObjectChangePolicy

      public void setObjectChangePolicy(ObjectChangePolicy policy)
      PUBLIC: Set the ObjectChangePolicy for this descriptor.
    • setHistoryPolicy

      public void setHistoryPolicy(HistoryPolicy policy)
      PUBLIC: Set the HistoryPolicy for this descriptor.
    • setCacheInterceptorClass

      public void setCacheInterceptorClass(Class<? extends CacheInterceptor> cacheInterceptorClass)
      PUBLIC: A CacheInterceptor is an adaptor that when overridden and assigned to a Descriptor all interaction between EclipseLink and the internal cache for that class will pass through the Interceptor. Advanced users could use this interceptor to audit, profile or log cache access. This Interceptor could also be used to redirect or augment the TopLink cache with an alternate cache mechanism. EclipseLink's configurated IdentityMaps will be passed to the Interceptor constructor. As with IdentityMaps an entire class inheritance hierarchy will share the same interceptor.
      See Also:
    • setCacheInterceptorClassName

      public void setCacheInterceptorClassName(String cacheInterceptorClassName)
      PUBLIC: A CacheInterceptor is an adaptor that when overridden and assigned to a Descriptor all interaction between EclipseLink and the internal cache for that class will pass through the Interceptor. Advanced users could use this interceptor to audit, profile or log cache access. This Interceptor could also be used to redirect or augment the TopLink cache with an alternate cache mechanism. EclipseLink's configurated IdentityMaps will be passed to the Interceptor constructor. As with IdentityMaps an entire class inheritance hierarchy will share the same interceptor.
      See Also:
    • setCacheInvalidationPolicy

      public void setCacheInvalidationPolicy(CacheInvalidationPolicy policy)
      PUBLIC: Set the Cache Invalidation Policy for this descriptor.
      See Also:
    • setConstraintDependencies

      public void setConstraintDependencies(Vector constraintDependencies)
      ADVANCED: automatically orders database access through the foreign key information provided in 1:1 and 1:m mappings. In some case when 1:1 are not defined it may be required to tell the descriptor about a constraint, this defines that this descriptor has a foreign key constraint to another class and must be inserted after instances of the other class.
    • setCopyPolicy

      public void setCopyPolicy(CopyPolicy policy)
      INTERNAL: Set the copy policy. This would be 'protected' but the EJB stuff in another package needs it to be public
    • setCopyPolicyClassName

      public void setCopyPolicyClassName(String className)
      INTERNAL: Sets the name of a Class that implements CopyPolicy Will be instantiatied as a copy policy at initialization times using the no-args constructor
    • setDefaultTable

      public void setDefaultTable(DatabaseTable defaultTable)
      INTERNAL: The descriptors default table can be configured if the first table is not desired.
    • setDefaultTableName

      public void setDefaultTableName(String defaultTableName)
      PUBLIC: The descriptors default table can be configured if the first table is not desired.
    • setDescriptorCustomizerClassName

      public void setDescriptorCustomizerClassName(String descriptorCustomizerClassName)
      INTERNAL: Sets the JPA DescriptorCustomizer class name. DescriptorCustomizer is the JPA equivalent of an amendment method.
    • setDescriptorType

      public void setDescriptorType(int descriptorType)
      ADVANCED: set the descriptor type (NORMAL by default, others include INTERFACE, AGGREGATE, AGGREGATE COLLECTION)
    • setDescriptorTypeValue

      public void setDescriptorTypeValue(String value)
      INTERNAL: This method is explicitly used by the XML reader.
    • setEventManager

      public void setEventManager(DescriptorEventManager eventManager)
      INTERNAL: Set the event manager for the descriptor. The event manager is responsible for managing the pre/post selectors.
      Specified by:
      setEventManager in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
    • setExistenceChecking

      public void setExistenceChecking(String token) throws DescriptorException
      INTERNAL: OBSOLETE - old reader. This method is explicitly used by the Builder only.
      Throws:
      DescriptorException
    • setFields

      public void setFields(Vector<DatabaseField> fields)
      INTERNAL: Set the fields used by this descriptor.
    • setForeignKeyFieldNamesForMultipleTable

      public void setForeignKeyFieldNamesForMultipleTable(List<Association> associations) throws DescriptorException
      INTERNAL: This method is used by the XML Deployment ClassDescriptor to read and write these mappings
      Throws:
      DescriptorException
    • setFullyMergeEntity

      public void setFullyMergeEntity(boolean fullyMergeEntity)
      Parameters:
      fullyMergeEntity - the fullyMergeEntity to set
    • setIdentityMapClass

      public void setIdentityMapClass(Class<? extends IdentityMap> theIdentityMapClass)
      PUBLIC: Set the class of identity map to be used by this descriptor. The default is the "FullIdentityMap".
    • setIdentityMapSize

      public void setIdentityMapSize(int identityMapSize)
      PUBLIC: Set the size of the identity map to be used by this descriptor. The default is the 100.
    • setInheritancePolicy

      public void setInheritancePolicy(InheritancePolicy inheritancePolicy)
      INTERNAL: Sets the inheritance policy.
      Specified by:
      setInheritancePolicy in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
    • setReturningPolicy

      public void setReturningPolicy(ReturningPolicy returningPolicy)
      PUBLIC: Sets the returning policy.
    • setInitializationStage

      protected void setInitializationStage(int initializationStage)
      INTERNAL:
    • setInstantiationPolicy

      public void setInstantiationPolicy(InstantiationPolicy instantiationPolicy)
      INTERNAL: Sets the instantiation policy.
      Specified by:
      setInstantiationPolicy in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
    • setInterfaceInitializationStage

      protected void setInterfaceInitializationStage(int interfaceInitializationStage)
      INTERNAL:
    • setInterfacePolicy

      public void setInterfacePolicy(InterfacePolicy interfacePolicy)
      INTERNAL: Sets the interface policy.
    • setInternalDefaultTable

      public void setInternalDefaultTable()
      INTERNAL: Set the default table if one if not already set. This method will extract the default table.
    • setInternalDefaultTable

      public void setInternalDefaultTable(DatabaseTable defaultTable)
      INTERNAL: Set the default table if one if not already set. This method will set the table that is provided as the default.
    • setCacheable

      public void setCacheable(Boolean cacheable)
      INTERNAL: Set entity @Cacheable annotation value in cache configuration object.
      Parameters:
      cacheable - Entity @Cacheable annotation value for current class or null if @Cacheable annotation is not set. Parent values are ignored, value shall refer to current class only. This value should be set only when SharedCacheMode allows to override caching on entity level (DISABLE_SELECTIVE or ENABLE_SELECTIVE).
    • getCacheIsolation

      public CacheIsolationType getCacheIsolation()
      PUBLIC: Controls how the Entity instances will be cached. See the CacheIsolationType for details on the options.
      Returns:
      the isolationType
    • setCacheIsolation

      public void setCacheIsolation(CacheIsolationType isolationType)
      PUBLIC: Controls how the Entity instances and data will be cached. See the CacheIsolationType for details on the options. To disable all second level caching simply set CacheIsolationType.ISOLATED. Note that setting the isolation will automatically set the corresponding cacheSynchronizationType. ISOLATED = DO_NOT_SEND_CHANGES, PROTECTED and SHARED = SEND_OBJECT_CHANGES
    • shouldIsolateObjectsInUnitOfWork

      public boolean shouldIsolateObjectsInUnitOfWork()
      INTERNAL: Return if the unit of work should by-pass the session cache. Objects will be built in the unit of work, and never merged into the session cache.
    • shouldIsolateProtectedObjectsInUnitOfWork

      public boolean shouldIsolateProtectedObjectsInUnitOfWork()
      INTERNAL: Return if the unit of work should by-pass the IsolatedSession cache. Objects will be built/merged into the unit of work and into the session cache. but not built/merge into the IsolatedClientSession cache.
    • shouldIsolateObjectsInUnitOfWorkEarlyTransaction

      public boolean shouldIsolateObjectsInUnitOfWorkEarlyTransaction()
      INTERNAL: Return if the unit of work should by-pass the session cache after an early transaction.
    • shouldUseSessionCacheInUnitOfWorkEarlyTransaction

      public boolean shouldUseSessionCacheInUnitOfWorkEarlyTransaction()
      INTERNAL: Return if the unit of work should use the session cache after an early transaction.
    • getUnconvertedProperties

      public Map<String,List<String>> getUnconvertedProperties()
      INTERNAL: Used to store un-converted properties, which are subsequenctly converted at runtime (through the convertClassNamesToClasses method.
    • getUnitOfWorkCacheIsolationLevel

      public int getUnitOfWorkCacheIsolationLevel()
      ADVANCED: Return the unit of work cache isolation setting. This setting configures how the session cache will be used in a unit of work.
      See Also:
    • setUnitOfWorkCacheIsolationLevel

      public void setUnitOfWorkCacheIsolationLevel(int unitOfWorkCacheIsolationLevel)
      ADVANCED: This setting configures how the session cache will be used in a unit of work. Most of the options only apply to a unit of work in an early transaction, such as a unit of work that was flushed (writeChanges), issued a modify query, or acquired a pessimistic lock.

      USE_SESSION_CACHE_AFTER_TRANSACTION - Objects built from new data accessed after a unit of work early transaction are stored in the session cache. This options is the most efficient as it allows the cache to be used after an early transaction. This should only be used if it is known that this class is not modified in the transaction, otherwise this could cause uncommitted data to be loaded into the session cache. ISOLATE_NEW_DATA_AFTER_TRANSACTION - Default (when using caching): Objects built from new data accessed after a unit of work early transaction are only stored in the unit of work. This still allows previously cached objects to be accessed in the unit of work after an early transaction, but ensures uncommitted data will never be put in the session cache by storing any object built from new data only in the unit of work. ISOLATE_CACHE_AFTER_TRANSACTION - After a unit of work early transaction the session cache is no longer used for this class. Objects will be directly built from the database data and only stored in the unit of work, even if previously cached. Note that this may lead to poor performance as the session cache is bypassed after an early transaction. ISOLATE_CACHE_ALWAYS - Default (when using isolated cache): The session cache will never be used for this class. Objects will be directly built from the database data and only stored in the unit of work. New objects and changes will also never be merged into the session cache. Note that this may lead to poor performance as the session cache is bypassed, however if this class is isolated or pessimistic locked and always accessed in a transaction, this can avoid having to build two copies of the object.

    • setHasRelationships

      public void setHasRelationships(boolean hasRelationships)
      INTERNAL: set whether this descriptor has any relationships through its mappings, through inheritance, or through aggregates
    • setJavaClass

      public void setJavaClass(Class<?> theJavaClass)
      PUBLIC: Set the Java class that this descriptor maps. Every descriptor maps one and only one class.
      Specified by:
      setJavaClass in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
    • setJavaClassName

      public void setJavaClassName(String theJavaClassName)
      INTERNAL: Return the java class name, used by the MW.
    • setJavaInterface

      public void setJavaInterface(Class<?> theJavaInterface)
      PUBLIC: Sets the descriptor to be for an interface. An interface descriptor allows for other classes to reference an interface or one of several other classes. The implementor classes can be completely unrelated in term of the database stored in distinct tables. Queries can also be done for the interface which will query each of the implementor classes. An interface descriptor cannot define any mappings as an interface is just API and not state, a interface descriptor should define the common query key of its implementors to allow querying. An interface descriptor also does not define a primary key or table or other settings. If an interface only has a single implementor (i.e. a classes public interface or remote) then an interface descriptor should not be defined for it and relationships should be to the implementor class not the interface, in this case the implementor class can add the interface through its interface policy to map queries on the interface to it.
    • setJavaInterfaceName

      public void setJavaInterfaceName(String theJavaInterfaceName)
      INTERNAL: Return the java interface name, used by the MW.
    • setLockableMappings

      public void setLockableMappings(List<DatabaseMapping> lockableMappings)
      INTERNAL: Set the list of lockable mappings for this project This method is provided for CMP use. Normally, the lockable mappings are initialized at descriptor initialization time.
    • setMappings

      public void setMappings(Vector<DatabaseMapping> mappings)
      INTERNAL: Set the mappings.
    • setMultipleTableForeignKeys

      protected void setMultipleTableForeignKeys(Map<DatabaseTable,Set<DatabaseTable>> newValue)
      INTERNAL:
      See Also:
    • setMultipleTableInsertOrder

      public void setMultipleTableInsertOrder(List<DatabaseTable> newValue)
      ADVANCED: Sets the List of DatabaseTables in the order which INSERTS should take place. This is normally computed correctly by , however in advanced cases in it may be overridden.
    • setMultitenantPolicy

      public void setMultitenantPolicy(MultitenantPolicy multitenantPolicy)
      INTERNAL: Set a multitenant policy on the descriptor.
    • isCascadeOnDeleteSetOnDatabaseOnSecondaryTables

      public boolean isCascadeOnDeleteSetOnDatabaseOnSecondaryTables()
      ADVANCED: Return if delete cascading has been set on the database for the descriptor's multiple tables.
    • setIsCascadeOnDeleteSetOnDatabaseOnSecondaryTables

      public void setIsCascadeOnDeleteSetOnDatabaseOnSecondaryTables(boolean isCascadeOnDeleteSetOnDatabaseOnSecondaryTables)
      ADVANCED: Set if delete cascading has been set on the database for the descriptor's multiple tables. This will avoid the delete SQL being generated for those tables.
    • setObjectBuilder

      protected void setObjectBuilder(ObjectBuilder builder)
      INTERNAL: Set the ObjectBuilder.
      Specified by:
      setObjectBuilder in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
    • setOptimisticLockingPolicy

      public void setOptimisticLockingPolicy(OptimisticLockingPolicy optimisticLockingPolicy)
      PUBLIC: Set the OptimisticLockingPolicy. This can be one of the provided locking policies or a user defined policy.
      See Also:
    • setPrimaryKeyFieldName

      public void setPrimaryKeyFieldName(String fieldName)
      PUBLIC: Specify the primary key field of the descriptors table. This should only be called if it is a singlton primary key field, otherwise addPrimaryKeyFieldName should be called. If the descriptor has many tables, this must be the primary key in all of the tables.
      See Also:
    • setPrimaryKeyFieldNames

      public void setPrimaryKeyFieldNames(Vector primaryKeyFieldsName)
      PUBLIC: User can specify a vector of all the primary key field names if primary key is composite.
      Specified by:
      setPrimaryKeyFieldNames in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
      See Also:
    • setPrimaryKeyFields

      public void setPrimaryKeyFields(List<DatabaseField> thePrimaryKeyFields)
      INTERNAL: Set the primary key fields
      Specified by:
      setPrimaryKeyFields in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
      See Also:
    • setProperties

      public void setProperties(Map properties)
      INTERNAL: Set the user defined properties.
    • setProperty

      public void setProperty(String name, Object value)
      PUBLIC: Set the user defined property.
    • setQueryKeys

      public void setQueryKeys(Map<String,QueryKey> queryKeys)
      INTERNAL: Set the query keys.
    • setQueryManager

      public void setQueryManager(DescriptorQueryManager queryManager)
      INTERNAL: Set the query manager.
    • setRemoteIdentityMapClass

      public void setRemoteIdentityMapClass(Class<? extends IdentityMap> theIdentityMapClass)
      PUBLIC: Set the class of identity map to be used by this descriptor. The default is the "FullIdentityMap".
    • setRemoteIdentityMapSize

      public void setRemoteIdentityMapSize(int identityMapSize)
      PUBLIC: Set the size of the identity map to be used by this descriptor. The default is the 100.
    • setSequenceNumberField

      public void setSequenceNumberField(DatabaseField sequenceNumberField)
      INTERNAL: Set the sequence number field.
    • setSequenceNumberFieldName

      public void setSequenceNumberFieldName(String fieldName)
      PUBLIC: Set the sequence number field name. This is the field in the descriptors table that needs its value to be generated. This is normally the primary key field of the descriptor.
    • setSequenceNumberName

      public void setSequenceNumberName(String name)
      PUBLIC: Set the sequence number name. This is the seq_name part of the row stored in the sequence table for this descriptor. If using Oracle native sequencing this is the name of the Oracle sequence object. If using Sybase native sequencing this name has no meaning, but should still be set for compatibility. The name does not have to be unique among descriptors, as having descriptors share sequences can improve pre-allocation performance.
    • setSessionName

      protected void setSessionName(String sessionName)
      INTERNAL: Set the name of the session local to this descriptor. This is used by the session broker.
    • setShouldAlwaysConformResultsInUnitOfWork

      public void setShouldAlwaysConformResultsInUnitOfWork(boolean shouldAlwaysConformResultsInUnitOfWork)
      PUBLIC: set if the descriptor is defined to always conform the results in unit of work in read query.
    • setShouldAlwaysRefreshCache

      public void setShouldAlwaysRefreshCache(boolean shouldAlwaysRefreshCache)
      PUBLIC: When the shouldAlwaysRefreshCache argument passed into this method is true, this method configures a ClassDescriptor to always refresh the cache if data is received from the database by any query.

      However, if a query hits the cache, data is not refreshed regardless of how this setting is configured. For example, by default, when a query for a single object based on its primary key is executed, OracleAS TopLink will first look in the cache for the object. If the object is in the cache, the cached object is returned and data is not refreshed. To avoid cache hits, use the disableCacheHits() method.

      Also note that the UnitOfWork will not refresh its registered objects.

      Use this property with caution because it can lead to poor performance and may refresh on queries when it is not desired. Normally, if you require fresh data, it is better to configure a query with ObjectLevelReadQuery.refreshIdentityMapResult(). To ensure that refreshes are only done when required, use this method in conjunction with onlyRefreshCacheIfNewerVersion().

      When the shouldAlwaysRefreshCache argument passed into this method is false, this method ensures that a ClassDescriptor is not configured to always refresh the cache if data is received from the database by any query.

      See Also:
    • setShouldAlwaysRefreshCacheOnRemote

      public void setShouldAlwaysRefreshCacheOnRemote(boolean shouldAlwaysRefreshCacheOnRemote)
      PUBLIC: When the shouldAlwaysRefreshCacheOnRemote argument passed into this method is true, this method configures a ClassDescriptor to always remotely refresh the cache if data is received from the database by any query in a RemoteSession. However, if a query hits the cache, data is not refreshed regardless of how this setting is configured. For example, by default, when a query for a single object based on its primary key is executed, OracleAS TopLink will first look in the cache for the object. If the object is in the cache, the cached object is returned and data is not refreshed. To avoid cache hits, use the disableCacheHitsOnRemote() method.

      Also note that the UnitOfWork will not refresh its registered objects.

      Use this property with caution because it can lead to poor performance and may refresh on queries when it is not desired. Normally, if you require fresh data, it is better to configure a query with ObjectLevelReadQuery.refreshIdentityMapResult(). To ensure that refreshes are only done when required, use this method in conjunction with onlyRefreshCacheIfNewerVersion().

      When the shouldAlwaysRefreshCacheOnRemote argument passed into this method is false, this method ensures that a ClassDescriptor is not configured to always remotely refresh the cache if data is received from the database by any query in a RemoteSession.

      See Also:
    • setShouldBeReadOnly

      public void setShouldBeReadOnly(boolean shouldBeReadOnly)
      PUBLIC: Define if the descriptor reference class is read-only
    • setReadOnly

      public void setReadOnly()
      PUBLIC: Set the descriptor to be read-only. Declaring a descriptor is read-only means that instances of the reference class will never be modified. Read-only descriptor is usually used in the unit of work to gain performance as there is no need for the registration, clone and merge for the read-only classes.
    • setShouldDisableCacheHits

      public void setShouldDisableCacheHits(boolean shouldDisableCacheHits)
      PUBLIC: Set if cache hits on primary key read object queries should be disabled.
      See Also:
    • setShouldDisableCacheHitsOnRemote

      public void setShouldDisableCacheHitsOnRemote(boolean shouldDisableCacheHitsOnRemote)
      PUBLIC: Set if the remote session cache hits on primary key read object queries is allowed or not.
      See Also:
    • setShouldLockForClone

      public void setShouldLockForClone(boolean shouldLockForClone)
      ADVANCED: When set to false, this setting will allow the UOW to avoid locking the shared cache instance in order to perform a clone. Caution should be taken as setting this to false may allow cloning of partial updates
    • setShouldOnlyRefreshCacheIfNewerVersion

      public void setShouldOnlyRefreshCacheIfNewerVersion(boolean shouldOnlyRefreshCacheIfNewerVersion)
      PUBLIC: When the shouldOnlyRefreshCacheIfNewerVersion argument passed into this method is true, this method configures a ClassDescriptor to only refresh the cache if the data received from the database by a query is newer than the data in the cache (as determined by the optimistic locking field) and as long as one of the following is true:

      However, if a query hits the cache, data is not refreshed regardless of how this setting is configured. For example, by default, when a query for a single object based on its primary key is executed, OracleAS TopLink will first look in the cache for the object. If the object is in the cache, the cached object is returned and data is not refreshed. To avoid cache hits, use the disableCacheHits() method.

      Also note that the UnitOfWork will not refresh its registered objects.

      When the shouldOnlyRefreshCacheIfNewerVersion argument passed into this method is false, this method ensures that a ClassDescriptor is not configured to only refresh the cache if the data received from the database by a query is newer than the data in the cache (as determined by the optimistic locking field).

      See Also:
    • setShouldOrderMappings

      public void setShouldOrderMappings(boolean shouldOrderMappings)
      PUBLIC: This is set to turn off the ordering of mappings. By Default this is set to true. By ordering the mappings insures that object are merged in the right order. If the order of the mappings needs to be specified by the developer then set this to false and will use the order that the mappings were added to the descriptor
    • setShouldRegisterResultsInUnitOfWork

      public void setShouldRegisterResultsInUnitOfWork(boolean shouldRegisterResultsInUnitOfWork)
      INTERNAL: Set to false to have queries conform to a UnitOfWork without registering any additional objects not already in that UnitOfWork.
      See Also:
    • setTableName

      public void setTableName(String tableName) throws DescriptorException
      PUBLIC: Specify the table name for the class of objects the receiver describes. If the table has a qualifier it should be specified using the dot notation, (i.e. "userid.employee"). This method is used for single table.
      Throws:
      DescriptorException
    • setTableNames

      public void setTableNames(Vector tableNames)
      PUBLIC: Specify the all table names for the class of objects the receiver describes. If the table has a qualifier it should be specified using the dot notation, (i.e. "userid.employee"). This method is used for multiple tables
    • setTablePerClassPolicy

      public void setTablePerClassPolicy(TablePerClassPolicy tablePerClassPolicy)
      INTERNAL: Sets the table per class policy.
    • setTableQualifier

      public void setTableQualifier(String tableQualifier)
      PUBLIC: Set the table Qualifier for this descriptor. This table creator will be used for all tables in this descriptor
    • setTables

      public void setTables(Vector<DatabaseTable> theTables)
      INTERNAL: Sets the tables
    • setWrapperPolicy

      public void setWrapperPolicy(WrapperPolicy wrapperPolicy)
      ADVANCED: Sets the WrapperPolicy for this descriptor. This advanced feature can be used to wrap objects with other classes such as CORBA TIE objects or EJBs.
    • shouldAlwaysConformResultsInUnitOfWork

      public boolean shouldAlwaysConformResultsInUnitOfWork()
      PUBLIC: Return if the descriptor is defined to always conform the results in unit of work in read query.
    • shouldAlwaysRefreshCache

      public boolean shouldAlwaysRefreshCache()
      PUBLIC: This method returns true if the ClassDescriptor is configured to always refresh the cache if data is received from the database by any query. Otherwise, it returns false.
      See Also:
    • shouldAlwaysRefreshCacheOnRemote

      public boolean shouldAlwaysRefreshCacheOnRemote()
      PUBLIC: This method returns true if the ClassDescriptor is configured to always remotely refresh the cache if data is received from the database by any query in a RemoteSession. Otherwise, it returns false.
      See Also:
    • shouldBeReadOnly

      public boolean shouldBeReadOnly()
      PUBLIC: Return if the descriptor reference class is defined as read-only
    • shouldDisableCacheHits

      public boolean shouldDisableCacheHits()
      PUBLIC: Return if for cache hits on primary key read object queries to be disabled.
      See Also:
    • shouldDisableCacheHitsOnRemote

      public boolean shouldDisableCacheHitsOnRemote()
      PUBLIC: Return if the remote server session cache hits on primary key read object queries is aloowed or not.
      See Also:
    • shouldOnlyRefreshCacheIfNewerVersion

      public boolean shouldOnlyRefreshCacheIfNewerVersion()
      PUBLIC: This method returns true if the ClassDescriptor is configured to only refresh the cache if the data received from the database by a query is newer than the data in the cache (as determined by the optimistic locking field). Otherwise, it returns false.
      See Also:
    • shouldOrderMappings

      public boolean shouldOrderMappings()
      INTERNAL: Return if mappings should be ordered or not. By default this is set to true to prevent attributes from being merged in the wrong order
    • hasSimplePrimaryKey

      public boolean hasSimplePrimaryKey()
      INTERNAL: PERF: Return if the primary key is simple (direct-mapped) to allow fast extraction.
    • hasTablePerClassPolicy

      public boolean hasTablePerClassPolicy()
      INTERNAL: Return if this descriptor is involved in a table per class inheritance.
    • setHasSimplePrimaryKey

      public void setHasSimplePrimaryKey(boolean hasSimplePrimaryKey)
      INTERNAL: PERF: Set if the primary key is simple (direct-mapped) to allow fast extraction.
    • shouldAcquireCascadedLocks

      public boolean shouldAcquireCascadedLocks()
      INTERNAL: PERF: Return if deferred locks should be used. Used to optimize read locking. This is determined based on if any relationships do not use indirection.
    • setShouldAcquireCascadedLocks

      public void setShouldAcquireCascadedLocks(boolean shouldAcquireCascadedLocks)
      INTERNAL: PERF: Set if deferred locks should be used. This is determined based on if any relationships do not use indirection, but this provides a backdoor hook to force on if require because of events usage etc.
    • shouldUseAdditionalJoinExpression

      public boolean shouldUseAdditionalJoinExpression()
      PUBLIC: Return true if this descriptor should using an additional join expresison.
    • shouldUseCacheIdentityMap

      public boolean shouldUseCacheIdentityMap()
      PUBLIC: Return true if this descriptor is using CacheIdentityMap
    • shouldUseFullIdentityMap

      public boolean shouldUseFullIdentityMap()
      PUBLIC: Return true if this descriptor is using FullIdentityMap
    • shouldUseSoftIdentityMap

      public boolean shouldUseSoftIdentityMap()
      PUBLIC: Return true if this descriptor is using SoftIdentityMap
    • shouldUseRemoteSoftIdentityMap

      public boolean shouldUseRemoteSoftIdentityMap()
      PUBLIC: Return true if this descriptor is using SoftIdentityMap
    • shouldUseHardCacheWeakIdentityMap

      public boolean shouldUseHardCacheWeakIdentityMap()
      PUBLIC: Return true if this descriptor is using HardCacheWeakIdentityMap.
    • shouldUseNoIdentityMap

      public boolean shouldUseNoIdentityMap()
      PUBLIC: Return true if this descriptor is using NoIdentityMap
    • shouldRegisterResultsInUnitOfWork

      public boolean shouldRegisterResultsInUnitOfWork()
      INTERNAL: Allows one to do conforming in a UnitOfWork without registering. Queries executed on a UnitOfWork will only return working copies for objects that have already been registered.

      Extreme care should be taken in using this feature, for a user will get back a mix of registered and original (unregistered) objects.

      Best used with a WrapperPolicy where invoking on an object will trigger its registration (CMP). Without a WrapperPolicy registerExistingObject should be called on any object that you intend to change.

      Returns:
      true by default.
      See Also:
    • shouldUseRemoteCacheIdentityMap

      public boolean shouldUseRemoteCacheIdentityMap()
      PUBLIC: Return true if this descriptor is using CacheIdentityMap
    • shouldUseRemoteFullIdentityMap

      public boolean shouldUseRemoteFullIdentityMap()
      PUBLIC: Return true if this descriptor is using FullIdentityMap
    • shouldUseRemoteHardCacheWeakIdentityMap

      public boolean shouldUseRemoteHardCacheWeakIdentityMap()
      PUBLIC: Return true if this descriptor is using HardCacheWeakIdentityMap
    • shouldUseRemoteNoIdentityMap

      public boolean shouldUseRemoteNoIdentityMap()
      PUBLIC: Return true if this descriptor is using NoIdentityMap
    • shouldUseRemoteSoftCacheWeakIdentityMap

      public boolean shouldUseRemoteSoftCacheWeakIdentityMap()
      PUBLIC: Return true if this descriptor is using SoftCacheWeakIdentityMap
    • shouldUseRemoteWeakIdentityMap

      public boolean shouldUseRemoteWeakIdentityMap()
      PUBLIC: Return true if this descriptor is using WeakIdentityMap
    • shouldUseSoftCacheWeakIdentityMap

      public boolean shouldUseSoftCacheWeakIdentityMap()
      PUBLIC: Return true if this descriptor is using SoftCacheWeakIdentityMap.
    • shouldUseWeakIdentityMap

      public boolean shouldUseWeakIdentityMap()
      PUBLIC: Return true if this descriptor is using WeakIdentityMap
    • supportsChangeTracking

      public boolean supportsChangeTracking(Project project)
      INTERNAL: Returns whether this descriptor is capable of supporting weaved change tracking. This method is used before the project is initialized.
    • toString

      public String toString()
      PUBLIC: Returns a brief string representation of the receiver.
      Overrides:
      toString in class Object
    • useAllFieldsLocking

      public void useAllFieldsLocking()
      PUBLIC: Set the locking policy an all fields locking policy. A field locking policy is base on locking on all fields by comparing with their previous values to detect field-level collisions. Note: the unit of work must be used for all updates when using field locking.
      See Also:
    • useCacheIdentityMap

      public void useCacheIdentityMap()
      PUBLIC: Set the class of identity map to be the cache identity map. This map caches the LRU instances read from the database. Note: This map does not guarantee object identity. The default is the "SoftCacheWeakIdentityMap".
    • useChangedFieldsLocking

      public void useChangedFieldsLocking()
      PUBLIC: Set the locking policy a changed fields locking policy. A field locking policy is base on locking on all changed fields by comparing with their previous values to detect field-level collisions. Note: the unit of work must be used for all updates when using field locking.
      See Also:
    • useCloneCopyPolicy

      public void useCloneCopyPolicy()
      PUBLIC: Specifies that the creation of clones within a unit of work is done by sending the #clone() method to the original object. The #clone() method must return a logical shallow copy of the original object. This can be used if the default mechanism of creating a new instance does not handle the object's non-persistent attributes correctly.
      See Also:
    • useCloneCopyPolicy

      public void useCloneCopyPolicy(String cloneMethodName)
      PUBLIC: Specifies that the creation of clones within a unit of work is done by sending the cloneMethodName method to the original object. This method must return a logical shallow copy of the original object. This can be used if the default mechanism of creating a new instance does not handle the object's non-persistent attributes correctly.
      See Also:
    • useInstantiationCopyPolicy

      public void useInstantiationCopyPolicy()
      PUBLIC: Specifies that the creation of clones within a unit of work is done by building a new instance using the technique indicated by the descriptor's instantiation policy (which by default is to use the the default constructor). This new instance is then populated by using the descriptor's mappings to copy attributes from the original to the clone. This is the default. If another mechanism is desired the copy policy allows for a clone method to be called.
      See Also:
    • useDefaultConstructorInstantiationPolicy

      public void useDefaultConstructorInstantiationPolicy()
      PUBLIC: Use the default constructor to create new instances of objects built from the database. This is the default. The descriptor's class must either define a default constructor or define no constructors at all.
      See Also:
    • useFactoryInstantiationPolicy

      public void useFactoryInstantiationPolicy(Class<?> factoryClass, String methodName)
      PUBLIC: Use an object factory to create new instances of objects built from the database. The methodName is the name of the method that will be invoked on the factory. When invoked, it must return a new instance of the descriptor's class. The factory will be created by invoking the factoryClass's default constructor.
      See Also:
    • useFactoryInstantiationPolicy

      public void useFactoryInstantiationPolicy(String factoryClassName, String methodName)
      INTERNAL: Set the factory class name, used by the MW.
    • useFactoryInstantiationPolicy

      public void useFactoryInstantiationPolicy(Class<?> factoryClass, String methodName, String factoryMethodName)
      PUBLIC: Use an object factory to create new instances of objects built from the database. The factoryMethodName is a static method declared by the factoryClass. When invoked, it must return an instance of the factory. The methodName is the name of the method that will be invoked on the factory. When invoked, it must return a new instance of the descriptor's class.
      See Also:
    • useFactoryInstantiationPolicy

      public void useFactoryInstantiationPolicy(String factoryClassName, String methodName, String factoryMethodName)
      INTERNAL: Set the factory class name, used by the MW.
    • useFactoryInstantiationPolicy

      public void useFactoryInstantiationPolicy(Object factory, String methodName)
      PUBLIC: Use an object factory to create new instances of objects built from the database. The methodName is the name of the method that will be invoked on the factory. When invoked, it must return a new instance of the descriptor's class.
      See Also:
    • useFullIdentityMap

      public void useFullIdentityMap()
      PUBLIC: Set the class of identity map to be the full identity map. This map caches all instances read and grows to accomodate them. The default is the "SoftCacheWeakIdentityMap".
    • useHardCacheWeakIdentityMap

      public void useHardCacheWeakIdentityMap()
      PUBLIC: Set the class of identity map to be the hard cache weak identity map. This map uses weak references to only cache object in-memory. It also includes a secondary fixed sized hard cache to improve caching performance. This is provided because some Java VM's implement soft references differently. The default is the "SoftCacheWeakIdentityMap".
    • useSoftIdentityMap

      public void useSoftIdentityMap()
      PUBLIC: Set the class of identity map to be the soft identity map. This map uses soft references to only cache all object in-memory, until memory is low. Note that "low" is interpreted differently by different JVM's. The default is the "SoftCacheWeakIdentityMap".
    • useRemoteSoftIdentityMap

      public void useRemoteSoftIdentityMap()
      PUBLIC: Set the class of identity map to be the soft identity map. This map uses soft references to only cache all object in-memory, until memory is low. Note that "low" is interpreted differently by different JVM's. The default is the "SoftCacheWeakIdentityMap".
    • useMethodInstantiationPolicy

      public void useMethodInstantiationPolicy(String staticMethodName)
      PUBLIC: Use the specified static method to create new instances of objects built from the database. This method must be statically declared by the descriptor's class, and it must return a new instance of the descriptor's class.
      See Also:
    • useNoIdentityMap

      public void useNoIdentityMap()
      PUBLIC: Set the class of identity map to be the no identity map. This map does no caching. Note: This map does not maintain object identity. In general if caching is not desired a WeakIdentityMap should be used with an isolated descriptor. The default is the "SoftCacheWeakIdentityMap".
      See Also:
    • useRemoteCacheIdentityMap

      public void useRemoteCacheIdentityMap()
      PUBLIC: Set the class of identity map to be the cache identity map. This map caches the LRU instances read from the database. The default is the "SoftCacheWeakIdentityMap".
    • useRemoteFullIdentityMap

      public void useRemoteFullIdentityMap()
      PUBLIC: Set the class of identity map to be the full identity map. This map caches all instances read and grows to accomodate them. The default is the "SoftCacheWeakIdentityMap".
    • useRemoteHardCacheWeakIdentityMap

      public void useRemoteHardCacheWeakIdentityMap()
      PUBLIC: Set the class of identity map to be the hard cache weak identity map. This map uses weak references to only cache object in-memory. It also includes a secondary fixed sized soft cache to improve caching performance. This is provided because some Java VM's do not implement soft references correctly. The default is the "SoftCacheWeakIdentityMap".
    • useRemoteNoIdentityMap

      public void useRemoteNoIdentityMap()
      PUBLIC: Set the class of identity map to be the no identity map. This map does no caching. The default is the "SoftCacheWeakIdentityMap".
    • useRemoteSoftCacheWeakIdentityMap

      public void useRemoteSoftCacheWeakIdentityMap()
      PUBLIC: Set the class of identity map to be the soft cache weak identity map. The SoftCacheIdentityMap holds a fixed number of objects is memory (using SoftReferences) to improve caching. The default is the "SoftCacheWeakIdentityMap".
    • useRemoteWeakIdentityMap

      public void useRemoteWeakIdentityMap()
      PUBLIC: Set the class of identity map to be the weak identity map. The default is the "SoftCacheWeakIdentityMap".
    • useSelectedFieldsLocking

      public void useSelectedFieldsLocking(Vector fieldNames)
      PUBLIC: Set the locking policy a selected fields locking policy. A field locking policy is base on locking on the specified fields by comparing with their previous values to detect field-level collisions. Note: the unit of work must be used for all updates when using field locking.
      See Also:
    • usesFieldLocking

      public boolean usesFieldLocking()
      INTERNAL: Return true if the receiver uses either all or changed fields for optimistic locking.
    • useSoftCacheWeakIdentityMap

      public void useSoftCacheWeakIdentityMap()
      PUBLIC: Set the class of identity map to be the soft cache weak identity map. The SoftCacheIdentityMap holds a fixed number of objects is memory (using SoftReferences) to improve caching. The default is the "SoftCacheWeakIdentityMap".
    • usesOptimisticLocking

      public boolean usesOptimisticLocking()
      PUBLIC: Return true if the receiver uses write (optimistic) locking.
    • usesVersionLocking

      public boolean usesVersionLocking()
      PUBLIC: Return true if the receiver uses version optimistic locking.
    • usesSequenceNumbers

      public boolean usesSequenceNumbers()
      PUBLIC: Return true if the receiver uses sequence numbers.
    • useTimestampLocking

      public void useTimestampLocking(String writeLockFieldName)
      PUBLIC: Use the Timestamps locking policy and storing the value in the cache key #see useVersionLocking(String)
    • useTimestampLocking

      public void useTimestampLocking(String writeLockFieldName, boolean shouldStoreInCache)
      PUBLIC: Set the locking policy to use timestamp version locking. This updates the timestamp field on all updates, first comparing that the field has not changed to detect locking conflicts. Note: many database have limited precision of timestamps which can be an issue is highly concurrent systems. The parameter 'shouldStoreInCache' configures the version lock value to be stored in the cache or in the object. Note: if using a stateless model where the object can be passed to a client and then later updated in a different transaction context, then the version lock value should not be stored in the cache, but in the object to ensure it is the correct value for that object.
      See Also:
    • useVersionLocking

      public void useVersionLocking(String writeLockFieldName)
      PUBLIC: Default to use the version locking policy and storing the value in the cache key #see useVersionLocking(String)
    • useVersionLocking

      public void useVersionLocking(String writeLockFieldName, boolean shouldStoreInCache)
      PUBLIC: Set the locking policy to use numeric version locking. This updates the version field on all updates, first comparing that the field has not changed to detect locking conflicts. The parameter 'shouldStoreInCache' configures the version lock value to be stored in the cache or in the object. Note: if using a stateless model where the object can be passed to a client and then later updated in a different transaction context, then the version lock value should not be stored in the cache, but in the object to ensure it is the correct value for that object.
      See Also:
    • useWeakIdentityMap

      public void useWeakIdentityMap()
      PUBLIC: Set the class of identity map to be the weak identity map. The default is the "SoftCacheWeakIdentityMap".
    • validateAfterInitialization

      protected void validateAfterInitialization(AbstractSession session)
      INTERNAL: Validate the entire post-initialization descriptor.
    • validateBeforeInitialization

      protected void validateBeforeInitialization(AbstractSession session)
      INTERNAL: Validate the entire pre-initialization descriptor.
    • verifyTableQualifiers

      protected void verifyTableQualifiers(Platform platform)
      INTERNAL: Check that the qualifier on the table names are properly set.
    • getCMPPolicy

      public CMPPolicy getCMPPolicy()
      ADVANCED: Return the cmp descriptor that holds cmp specific information. A null return will mean that the descriptor does not represent an Entity, however it may still represent a MappedSuperclass. It will be null if it is not being used.
    • setCMPPolicy

      public void setCMPPolicy(CMPPolicy newCMPPolicy)
      ADVANCED: Set the cmp descriptor that holds cmp specific information.
    • getCachePolicy

      public CachePolicy getCachePolicy()
      Return the cache policy. The cache policy allows for the configuration of caching options.
    • setCachePolicy

      public void setCachePolicy(CachePolicy cachePolicy)
      ADVANCED: Set cache policy for the descriptor.
    • hasPessimisticLockingPolicy

      public boolean hasPessimisticLockingPolicy()
      INTERNAL:
    • getFetchGroupManager

      public FetchGroupManager getFetchGroupManager()
      PUBLIC: Get the fetch group manager for the descriptor. The fetch group manager is responsible for managing the fetch group behaviors and operations. To use the fetch group, the domain object must implement FetchGroupTracker interface. Otherwise, a descriptor validation exception would throw during initialization.
      See Also:
    • getFullyMergeEntity

      public boolean getFullyMergeEntity()
      Returns:
      the fullyMergeEntity
    • setFetchGroupManager

      public void setFetchGroupManager(FetchGroupManager fetchGroupManager)
      PUBLIC: Set the fetch group manager for the descriptor. The fetch group manager is responsible for managing the fetch group behaviors and operations.
    • hasFetchGroupManager

      public boolean hasFetchGroupManager()
      INTERNAL: Return if the descriptor has a fetch group manager associated with.
    • hasCascadeLockingPolicies

      public boolean hasCascadeLockingPolicies()
      INTERNAL:
    • hasCMPPolicy

      public boolean hasCMPPolicy()
      INTERNAL: Return if the descriptor has a CMP policy.
    • getDefaultFetchGroup

      public FetchGroup getDefaultFetchGroup()
      INTERNAL: Return the default fetch group on the descriptor. All read object and read all queries will use the default fetch group if no fetch group is explicitly defined for the query.
    • isReturnTypeRequiredForReturningPolicy

      public boolean isReturnTypeRequiredForReturningPolicy()
      INTERNAL: Indicates if a return type is required for the field set on the returning policy. For relational descriptors, this should always return true.
    • setIsNativeConnectionRequired

      public void setIsNativeConnectionRequired(boolean isNativeConnectionRequired)
      ADVANCED: Set if the descriptor requires usage of a native (unwrapped) JDBC connection. This may be required for some Oracle JDBC support when a wrapping DataSource is used.
    • isNativeConnectionRequired

      public boolean isNativeConnectionRequired()
      ADVANCED: Return if the descriptor requires usage of a native (unwrapped) JDBC connection. This may be required for some Oracle JDBC support when a wrapping DataSource is used.
    • setIdValidation

      public void setIdValidation(IdValidation idValidation)
      ADVANCED: Set what types are allowed as a primary key (id).
    • getIdValidation

      public IdValidation getIdValidation()
      ADVANCED: Return what types are allowed as a primary key (id).
    • getPrimaryKeyIdValidations

      public List<IdValidation> getPrimaryKeyIdValidations()
      ADVANCED: Return what types are allowed in each primary key field (id).
    • setPrimaryKeyIdValidations

      public void setPrimaryKeyIdValidations(List<IdValidation> primaryKeyIdValidations)
      ADVANCED: Return what types are allowed in each primary key field (id).
    • setCacheKeyType

      public void setCacheKeyType(CacheKeyType cacheKeyType)
      ADVANCED: Set what cache key type to use to store the object in the cache.
    • getCacheKeyType

      public CacheKeyType getCacheKeyType()
      ADVANCED: Return what cache key type to use to store the object in the cache.
    • getDefaultQueryRedirector

      public QueryRedirector getDefaultQueryRedirector()
      A Default Query Redirector will be applied to any executing object query that does not have a more precise default (like the default ReadObjectQuery Redirector) or a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • setDefaultQueryRedirector

      public void setDefaultQueryRedirector(QueryRedirector defaultRedirector)
      A Default Query Redirector will be applied to any executing object query that does not have a more precise default (like the default ReadObjectQuery Redirector) or a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • getDefaultReadAllQueryRedirector

      public QueryRedirector getDefaultReadAllQueryRedirector()
      A Default ReadAllQuery Redirector will be applied to any executing ReadAllQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • setDefaultReadAllQueryRedirector

      public void setDefaultReadAllQueryRedirector(QueryRedirector defaultReadAllQueryRedirector)
      A Default ReadAllQuery Redirector will be applied to any executing ReadAllQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • getDefaultReadObjectQueryRedirector

      public QueryRedirector getDefaultReadObjectQueryRedirector()
      A Default ReadObjectQuery Redirector will be applied to any executing ReadObjectQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • setDefaultReadObjectQueryRedirector

      public void setDefaultReadObjectQueryRedirector(QueryRedirector defaultReadObjectQueryRedirector)
      A Default ReadObjectQuery Redirector will be applied to any executing ReadObjectQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • getDefaultReportQueryRedirector

      public QueryRedirector getDefaultReportQueryRedirector()
      A Default ReportQuery Redirector will be applied to any executing ReportQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • setDefaultReportQueryRedirector

      public void setDefaultReportQueryRedirector(QueryRedirector defaultReportQueryRedirector)
      A Default ReportQuery Redirector will be applied to any executing ReportQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • getDefaultUpdateObjectQueryRedirector

      public QueryRedirector getDefaultUpdateObjectQueryRedirector()
      A Default UpdateObjectQuery Redirector will be applied to any executing UpdateObjectQuery or UpdateAllQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • setDefaultUpdateObjectQueryRedirector

      public void setDefaultUpdateObjectQueryRedirector(QueryRedirector defaultUpdateQueryRedirector)
      A Default UpdateObjectQuery Redirector will be applied to any executing UpdateObjectQuery or UpdateAllQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • getDefaultInsertObjectQueryRedirector

      public QueryRedirector getDefaultInsertObjectQueryRedirector()
      A Default InsertObjectQuery Redirector will be applied to any executing InsertObjectQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • setDefaultInsertObjectQueryRedirector

      public void setDefaultInsertObjectQueryRedirector(QueryRedirector defaultInsertQueryRedirector)
      A Default InsertObjectQuery Redirector will be applied to any executing InsertObjectQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • getDefaultDeleteObjectQueryRedirector

      public QueryRedirector getDefaultDeleteObjectQueryRedirector()
      A Default DeleteObjectQuery Redirector will be applied to any executing DeleteObjectQuery or DeleteAllQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • setDefaultDeleteObjectQueryRedirector

      public void setDefaultDeleteObjectQueryRedirector(QueryRedirector defaultDeleteObjectQueryRedirector)
      A Default DeleteObjectQuery Redirector will be applied to any executing DeleteObjectQuery or DeleteAllQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • setDefaultQueryRedirectorClassName

      public void setDefaultQueryRedirectorClassName(String defaultQueryRedirectorClassName)
      A Default Query Redirector will be applied to any executing object query that does not have a more precise default (like the default ReadObjectQuery Redirector) or a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • setDefaultReadAllQueryRedirectorClassName

      public void setDefaultReadAllQueryRedirectorClassName(String defaultReadAllQueryRedirectorClassName)
      A Default ReadAllQuery Redirector will be applied to any executing ReadAllQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query exection preventing it or alternately performing some side effect like auditing.
      See Also:
    • setDefaultReadObjectQueryRedirectorClassName

      public void setDefaultReadObjectQueryRedirectorClassName(String defaultReadObjectQueryRedirectorClassName)
      A Default ReadObjectQuery Redirector will be applied to any executing ReadObjectQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • setDefaultReportQueryRedirectorClassName

      public void setDefaultReportQueryRedirectorClassName(String defaultReportQueryRedirectorClassName)
      A Default ReportQuery Redirector will be applied to any executing ReportQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • setDefaultUpdateObjectQueryRedirectorClassName

      public void setDefaultUpdateObjectQueryRedirectorClassName(String defaultUpdateObjectQueryRedirectorClassName)
      A Default UpdateObjectQuery Redirector will be applied to any executing UpdateObjectQuery or UpdateAllQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query execution preventing it or alternately performing some side effect like auditing.
      See Also:
    • setDefaultInsertObjectQueryRedirectorClassName

      public void setDefaultInsertObjectQueryRedirectorClassName(String defaultInsertObjectQueryRedirectorClassName)
      A Default InsertObjectQuery Redirector will be applied to any executing InsertObjectQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query exection preventing it or alternately performing some side effect like auditing.
      See Also:
    • setDefaultDeleteObjectQueryRedirectorClassName

      public void setDefaultDeleteObjectQueryRedirectorClassName(String defaultDeleteObjectQueryRedirectorClassName)
      A Default DeleteObjectQuery Redirector will be applied to any executing DeleteObjectQuery or DeleteAllQuery that does not have a redirector set directly on the query. Query redirectors allow the user to intercept query exection preventing it or alternately performing some side effect like auditing.
      See Also:
    • getSequence

      public Sequence getSequence()
      Return the descriptor's sequence. This is normally set when the descriptor is initialized.
    • setSequence

      public void setSequence(Sequence sequence)
      Set the descriptor's sequence. This is normally set when the descriptor is initialized.
    • getMappingsPostCalculateChanges

      public List<DatabaseMapping> getMappingsPostCalculateChanges()
      Mappings that require postCalculateChanges method to be called
    • hasMappingsPostCalculateChanges

      public boolean hasMappingsPostCalculateChanges()
      Are there any mappings that require postCalculateChanges method to be called.
    • addMappingsPostCalculateChanges

      public void addMappingsPostCalculateChanges(DatabaseMapping mapping)
      Add a mapping to the list of mappings that require postCalculateChanges method to be called.
    • getMappingsPostCalculateChangesOnDeleted

      public List<DatabaseMapping> getMappingsPostCalculateChangesOnDeleted()
      Mappings that require mappingsPostCalculateChangesOnDeleted method to be called
    • hasMappingsPostCalculateChangesOnDeleted

      public boolean hasMappingsPostCalculateChangesOnDeleted()
      Are there any mappings that require mappingsPostCalculateChangesOnDeleted method to be called.
    • addMappingsPostCalculateChangesOnDeleted

      public void addMappingsPostCalculateChangesOnDeleted(DatabaseMapping mapping)
      Add a mapping to the list of mappings that require mappingsPostCalculateChangesOnDeleted method to be called.
    • hasMultipleTableConstraintDependecy

      public boolean hasMultipleTableConstraintDependecy()
      Return if any mapping reference a field in a secondary table. This is used to disable deferring multiple table writes.
    • hasMultitenantPolicy

      public boolean hasMultitenantPolicy()
      Return true if the descriptor has a multitenant policy
    • hasTablePerMultitenantPolicy

      public boolean hasTablePerMultitenantPolicy()
      PUBLIC
      Returns:
      true if this descriptor is configured with a table per tenant policy.
    • hasUnconvertedProperties

      public boolean hasUnconvertedProperties()
      INTERNAL: Used to store un-converted properties, which are subsequenctly converted at runtime (through the convertClassNamesToClasses method.
    • setHasMultipleTableConstraintDependecy

      public void setHasMultipleTableConstraintDependecy(boolean hasMultipleTableConstraintDependecy)
      Set if any mapping reference a field in a secondary table. This is used to disable deferring multiple table writes.
    • usesPropertyAccessForWeaving

      public boolean usesPropertyAccessForWeaving()
      INTERNAL: Return whether this descriptor uses property access. This information is used to modify the behavior of some of our weaving features
    • usePropertyAccessForWeaving

      public void usePropertyAccessForWeaving()
      INTERNAL: Record that this descriptor uses property access. This information is used to modify the behavior of some of our weaving features
    • getVirtualAttributeMethods

      public List<VirtualAttributeMethodInfo> getVirtualAttributeMethods()
      INTERNAL: Return the list of virtual methods sets for this Entity. This list is used to control which methods are weaved
    • setVirtualAttributeMethods

      public void setVirtualAttributeMethods(List<VirtualAttributeMethodInfo> virtualAttributeMethods)
      INTERNAL: Set the list of methods used my mappings with virtual access this list is used to determine which methods to weave
    • hasTargetForeignKeyMapping

      public boolean hasTargetForeignKeyMapping(AbstractSession session)
      INTERNAL: Indicates whether descriptor has at least one target foreign key mapping
    • getAttributeGroup

      public AttributeGroup getAttributeGroup(String name)
      Description copied from class: CoreDescriptor
      PUBLIC: Returns the attribute group corresponding to the name provided. If no group is found with the specified name, null is returned.
      Overrides:
      getAttributeGroup in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
    • getAttributeGroups

      public Map<String,AttributeGroup> getAttributeGroups()
      Description copied from class: CoreDescriptor
      ADVANCED: Returns the attribute groups for this Descriptor.
      Overrides:
      getAttributeGroups in class CoreDescriptor<AttributeGroup,DescriptorEventManager,DatabaseField,InheritancePolicy,InstantiationPolicy,Vector,ObjectBuilder>
    • clearReferencingClasses

      public void clearReferencingClasses()
      INTERNAL: Cleans referencingClasses set. Called from ClientSession for proper cleanup and avoid memory leak.