Class ClientSession
- java.lang.Object
- 
- org.eclipse.persistence.internal.core.sessions.CoreAbstractSession<ClassDescriptor,Login,org.eclipse.persistence.internal.databaseaccess.Platform,Project,SessionEventManager>
- 
- org.eclipse.persistence.internal.sessions.AbstractSession
- 
- org.eclipse.persistence.sessions.server.ClientSession
 
 
 
- 
- All Implemented Interfaces:
- java.io.Serializable,- java.lang.Cloneable,- CoreSession<ClassDescriptor,Login,org.eclipse.persistence.internal.databaseaccess.Platform,Project,SessionEventManager>,- CommandProcessor,- Session
 
 public class ClientSession extends org.eclipse.persistence.internal.sessions.AbstractSessionPurpose: Acts as a client to the server session.Description: This session is brokered by the server session for use in three-tiered applications. It is used to store the context of the connection, i.e. the login to be used for this client. This allows each client connected to the server to contain its own user login. Responsibilities: - Allow units of work to be acquired and pass them the client login's exclusive connection.
- Forward all requests and queries to its parent server session.
 This class is an implementation of Session. Please refer to that class for a full API. The public interface should be used.- See Also:
- Server,- Session,- UnitOfWork, Serialized Form
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected ConnectionPolicyconnectionPolicyprotected booleanisActiveprotected ServerSessionparentprotected org.eclipse.persistence.internal.sequencing.Sequencingsequencingprotected java.util.Map<java.lang.String,org.eclipse.persistence.internal.databaseaccess.Accessor>writeConnections- 
Fields inherited from class org.eclipse.persistence.internal.sessions.AbstractSessionaccessors, activeCommandThreads, attributeGroups, broker, commandManager, commitManager, defaultReferenceMode, deferredEvents, descriptors, eventManager, exceptionHandler, externalTransactionController, identityMapAccessor, injectionManager, integrityChecker, isConcurrent, isExecutingEvents, isFinalizersEnabled, isInBroker, isInProfile, isLoggingOff, isSynchronized, jpaQueriesProcessed, lastDescriptorAccessed, logSessionString, metadatalistener, multitenantContextProperties, name, numberOfActiveUnitsOfWork, objectsLockedForClone, partitioningPolicy, pessimisticLockTimeoutDefault, pessimisticLockTimeoutUnitDefault, platform, profiler, project, properties, queries, queryBuilder, queryTimeoutDefault, queryTimeoutUnitDefault, serializer, sessionLog, shouldCheckWriteLock, shouldOptimizeResultSetAccess, shouldPropagateChanges, staticMetamodelClasses, tablePerTenantDescriptors, tablePerTenantQueries, tolerateInvalidJPQL, transactionMutex, wasJTSTransactionInternallyStarted
 - 
Fields inherited from interface org.eclipse.persistence.sessions.coordination.CommandProcessorLOG_DEBUG, LOG_ERROR, LOG_INFO, LOG_WARNING
 
- 
 - 
Constructor SummaryConstructors Modifier Constructor Description protectedClientSession(Project project)ClientSession(ServerSession parent, ConnectionPolicy connectionPolicy)INTERNAL: Create and return a new client session.ClientSession(ServerSession parent, ConnectionPolicy connectionPolicy, java.util.Map properties)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description org.eclipse.persistence.internal.databaseaccess.AccessoraddWriteConnection(java.lang.String poolName, org.eclipse.persistence.internal.databaseaccess.Accessor writeConnection)INTERNAL: Add the connection to the client session.voidbasicCommitTransaction()INTERNAL: This is internal to the unit of work and should not be called otherwise.voidbasicRollbackTransaction()INTERNAL: This is internal to the unit of work and should not be called otherwise.voidconnect(org.eclipse.persistence.internal.databaseaccess.Accessor accessor)INTERNAL: Connect the session only (this must be the write connection as the read is shared).booleancontainsQuery(java.lang.String queryName)INTERNAL: Was PUBLIC: customer will be redirected toSession.voiddisconnect(org.eclipse.persistence.internal.databaseaccess.Accessor accessor)INTERNAL: Disconnect the accessor only (this must be the write connection as the read is shared).java.lang.ObjectexecuteCall(Call call, org.eclipse.persistence.internal.sessions.AbstractRecord translationRow, DatabaseQuery query)INTERNAL: Execute the call on the correct connection accessor.org.eclipse.persistence.internal.databaseaccess.AccessorgetAccessor()INTERNAL: This should normally not be used, getAccessors() should be used to support partitioning.java.util.Collection<org.eclipse.persistence.internal.databaseaccess.Accessor>getAccessors()INTERNAL: Return the write connections if in a transaction.CommandManagergetCommandManager()INTERNAL: Return the manager that allows this processor to receive or propagate commands from/to TopLink clusterConnectionPolicygetConnectionPolicy()ADVANCED: This method will return the connection policy that was used during the acquisition of this client session.java.util.Map<java.lang.Class,ClassDescriptor>getDescriptors()ADVANCED: Return all registered descriptors.org.eclipse.persistence.internal.sessions.AbstractSessiongetExecutionSession(DatabaseQuery query)INTERNAL: Gets the session which this query will be executed on.ServerSessiongetParent()INTERNAL: Return the parent.org.eclipse.persistence.internal.sessions.AbstractSessiongetParentIdentityMapSession(ClassDescriptor descriptor, boolean canReturnSelf, boolean terminalOnly)INTERNAL: Returns the appropriate IdentityMap session for this descriptor.java.lang.ObjectgetProperty(java.lang.String name)Search for and return the user defined property from this client session, if it not found then search for the property from parent.DatabaseQuerygetQuery(java.lang.String name)INTERNAL: Was PUBLIC: customer will be redirected toSession.DatabaseQuerygetQuery(java.lang.String name, java.util.Vector args)INTERNAL:org.eclipse.persistence.internal.sequencing.SequencinggetSequencing()INTERNAL: Return the Sequencing object used by the session.ServerPlatformgetServerPlatform()INTERNAL: Marked internal as this is not customer API but helper methods for accessing the server platform from within other sessions types (i.e. not DatabaseSession)java.lang.StringgetSessionTypeString()INTERNAL: Returns the type of session, its class.org.eclipse.persistence.internal.databaseaccess.AccessorgetWriteConnection()INTERNAL: Return the connection to be used for database modification.java.util.Map<java.lang.String,org.eclipse.persistence.internal.databaseaccess.Accessor>getWriteConnections()INTERNAL: Return the map of write connections.booleanhasWriteConnection()INTERNAL: Return if this session has been connected.voidinitializeIdentityMapAccessor()INTERNAL: Set up the IdentityMapManager.voidinitializeSequencing()INTERNAL: was ADVANCED: Creates sequencing object for the session.booleanisActive()INTERNAL: Was PUBLIC: customer will be redirected toSession.booleanisClientSession()INTERNAL: Return if this session is a client session.booleanisConnected()INTERNAL: Was PUBLIC: customer will be redirected toSession.booleanisExclusiveConnectionRequired()INTERNAL: This method is called in case externalConnectionPooling is used.voidrelease()INTERNAL: Was PUBLIC: customer will be redirected toSession.voidreleaseConnectionAfterCall(DatabaseQuery query)INTERNAL: Release (if required) connection after call.voidreleaseJTSConnection()INTERNAL: Called in the end of beforeCompletion of external transaction synchronization listener.voidreleaseReadConnection(org.eclipse.persistence.internal.databaseaccess.Accessor connection)INTERNAL: Release the cursor query's connection.protected voidreleaseWriteConnection()INTERNAL: This is internal to the unit of work and should not be called otherwise.java.lang.ObjectretryQuery(DatabaseQuery query, org.eclipse.persistence.internal.sessions.AbstractRecord row, DatabaseException databaseException, int retryCount, org.eclipse.persistence.internal.sessions.AbstractSession executionSession)INTERNAL: A query execution failed due to an invalid query.DatabaseExceptionretryTransaction(org.eclipse.persistence.internal.databaseaccess.Accessor writeConnection, DatabaseException databaseException, int retryCount, org.eclipse.persistence.internal.sessions.AbstractSession executionSession)INTERNAL: A begin transaction failed.voidsetConnectionPolicy(ConnectionPolicy connectionPolicy)INTERNAL: Set the connection policy.protected voidsetIsActive(boolean isActive)INTERNAL: Set if the client session is active (has not been released).protected voidsetParent(ServerSession parent)INTERNAL: Set the parent.voidsetWriteConnection(org.eclipse.persistence.internal.databaseaccess.Accessor writeConnection)INTERNAL: Set the connection to be used for database modification.voidsetWriteConnections(java.util.Map<java.lang.String,org.eclipse.persistence.internal.databaseaccess.Accessor> writeConnections)INTERNAL: Set the connection to be used for database modification.booleanshouldPropagateChanges()INTERNAL: Return whether changes should be propagated to TopLink cluster.java.lang.StringtoString()INTERNAL: Print the connection status with the session.- 
Methods inherited from class org.eclipse.persistence.internal.sessions.AbstractSessionacquireHistoricalSession, acquireNonSynchronizedUnitOfWork, acquireNonSynchronizedUnitOfWork, acquireRepeatableWriteUnitOfWork, acquireUnitOfWork, acquireUnitOfWork, addAlias, addJPAQuery, addJPATablePerTenantQuery, addMultitenantContextProperty, addQuery, addQuery, addQuery, addStaticMetamodelClass, addTablePerTenantDescriptor, addTablePerTenantQuery, basicBeginTransaction, basicBeginTransaction, basicExecuteCall, beginExternalTransaction, beginTransaction, buildDefaultQueryBuilder, checkAndRefreshInvalidObject, checkHierarchyForDescriptor, cleanUpInjectionManager, clearDescriptors, clearIntegrityChecker, clearLastDescriptorAccessed, clearProfile, clearThreadsToWaitMergeManagerWaitingDeferredCacheKeys, clone, commitExternalTransaction, commitTransaction, compareObjects, compareObjectsDontMatch, config, copy, copy, copyDescriptorNamedQueries, copyDescriptorsFromProject, copyInternal, copyObject, copyObject, copyReadOnlyClasses, createCloneQueryValueHolder, createCloneTransformationValueHolder, createInjectionManager, createProtectedInstanceFromCachedData, deferEvent, deleteAllObjects, deleteAllObjects, deleteObject, doesObjectExist, dontLogMessages, endOperationProfile, endOperationProfile, executeDeferredEvents, executeNonSelectingCall, executeNonSelectingSQL, executeQuery, executeQuery, executeQuery, executeQuery, executeQuery, executeQuery, executeQuery, executeQuery, executeQuery, executeQuery, executeQuery, executeQuery, executeQuery, executeQuery, executeQuery, executeQuery, executeSelectingCall, executeSQL, fine, finer, finest, getAccessors, getActiveCommandThreads, getActiveSession, getActiveUnitOfWork, getAliasDescriptors, getAllQueries, getAsOfClause, getAttributeGroups, getBroker, getCacheKeyFromTargetSessionForMerge, getClassDescriptor, getClassDescriptor, getClassDescriptorForAlias, getCommitManager, getDatasourceLogin, getDatasourcePlatform, getDefaultReadOnlyClasses, getDefaultReferenceMode, getDescriptor, getDescriptor, getDescriptorForAlias, getEventManager, getExceptionHandler, getExceptionHandlerClass, getExternalTransactionController, getId, getIdentityMapAccessor, getIdentityMapAccessorInstance, getInjectionManager, getIntegrityChecker, getJPAQueries, getJPATablePerTenantQueries, getLoader, getLog, getLogin, getLogLevel, getLogLevel, getLogSessionString, getMappedSuperclass, getMultitenantContextProperties, getName, getNextQueryId, getNextSequenceNumberValue, getNumberOfActiveUnitsOfWork, getParentIdentityMapSession, getParentIdentityMapSession, getPartitioningPolicy, getPessimisticLockTimeoutDefault, getPessimisticLockTimeoutUnitDefault, getPlatform, getPlatform, getProfiler, getProject, getProperties, getQueries, getQuery, getQuery, getQueryBuilder, getQueryTimeoutDefault, getQueryTimeoutUnitDefault, getRefreshMetadataListener, getRootSession, getSerializer, getSessionForClass, getSessionForName, getSessionLog, getStaticMetamodelClass, getTablePerTenantDescriptors, getTablePerTenantQueries, getThreadsToWaitMergeManagerWaitingDeferredCacheKeysSnapshot, getTransactionMutex, handleException, handleSevere, hasBroker, hasCommitManager, hasDescriptor, hasEventManager, hasExceptionHandler, hasExternalTransactionController, hasProperties, hasTablePerTenantDescriptors, hasTablePerTenantQueries, incrementProfile, incrementProfile, info, insertObject, internalExecuteQuery, isBroker, isClassReadOnly, isClassReadOnly, isConcurrent, isConsideredInvalid, isDatabaseSession, isDistributedSession, isExclusiveIsolatedClientSession, isFinalizersEnabled, isHistoricalSession, isInBroker, isInProfile, isInTransaction, isIsolatedClientSession, isJPAQueriesProcessed, isLoggingOff, isProtectedSession, isRemoteSession, isRemoteUnitOfWork, isServerSession, isSessionBroker, isSynchronized, isUnitOfWork, keyFromObject, keyFromObject, load, load, log, log, log, log, log, log, log, log, log, log, logMessage, logMessage, logThrowable, postAcquireConnection, prepareDatabaseQuery, preReleaseConnection, priviledgedExecuteNonSelectingCall, priviledgedExecuteSelectingCall, processCommand, processJPAQueries, processJPAQuery, readAllObjects, readAllObjects, readAllObjects, readAllObjects, readObject, readObject, readObject, readObject, readObject, refreshAndLockObject, refreshAndLockObject, refreshObject, registerFinalizer, releaseUnitOfWork, removeProperty, removeQuery, removeQuery, retrieveCacheKey, rollbackExternalTransaction, rollbackTransaction, setAccessor, setBroker, setCommandManager, setCommitManager, setDatasourceLogin, setDefaultReferenceMode, setEventManager, setExceptionHandler, setExternalTransactionController, setInjectionManager, setIntegrityChecker, setIsConcurrent, setIsFinalizersEnabled, setIsInBroker, setIsInProfile, setJPAQueriesProcessed, setLog, setLoggingOff, setLogin, setLogin, setLogLevel, setName, setNumberOfActiveUnitsOfWork, setPartitioningPolicy, setPessimisticLockTimeoutDefault, setPessimisticLockTimeoutUnitDefault, setProfiler, setProject, setProperties, setProperty, setQueries, setQueryBuilder, setQueryTimeoutDefault, setQueryTimeoutUnitDefault, setRefreshMetadataListener, setSerializer, setSessionLog, setShouldOptimizeResultSetAccess, setShouldPropagateChanges, setSynchronized, setThreadsToWaitMergeManagerWaitingDeferredCacheKeys, setTolerateInvalidJPQL, setTransactionMutex, setWasJTSTransactionInternallyStarted, severe, shouldDisplayData, shouldLog, shouldLogMessages, shouldLogMessages, shouldOptimizeResultSetAccess, shouldTolerateInvalidJPQL, startOperationProfile, startOperationProfile, unwrapObject, updateObject, updateProfile, updateTablePerTenantDescriptors, validateCache, validateQuery, verifyDelete, warning, wasJTSTransactionInternallyStarted, wrapObject, writeAllObjectsWithChangeSet, writeObject, writesCompleted
 
- 
 
- 
- 
- 
Field Detail- 
parentprotected ServerSession parent 
 - 
connectionPolicyprotected ConnectionPolicy connectionPolicy 
 - 
writeConnectionsprotected java.util.Map<java.lang.String,org.eclipse.persistence.internal.databaseaccess.Accessor> writeConnections 
 - 
isActiveprotected boolean isActive 
 - 
sequencingprotected org.eclipse.persistence.internal.sequencing.Sequencing sequencing 
 
- 
 - 
Constructor Detail- 
ClientSessionpublic ClientSession(ServerSession parent, ConnectionPolicy connectionPolicy) INTERNAL: Create and return a new client session.
 - 
ClientSessionpublic ClientSession(ServerSession parent, ConnectionPolicy connectionPolicy, java.util.Map properties) 
 - 
ClientSessionprotected ClientSession(Project project) 
 
- 
 - 
Method Detail- 
releaseJTSConnectionpublic void releaseJTSConnection() INTERNAL: Called in the end of beforeCompletion of external transaction synchronization listener. Close the managed sql connection corresponding to the external transaction and releases accessor.- Overrides:
- releaseJTSConnectionin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
basicCommitTransactionpublic void basicCommitTransaction() INTERNAL: This is internal to the unit of work and should not be called otherwise.- Overrides:
- basicCommitTransactionin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
basicRollbackTransactionpublic void basicRollbackTransaction() INTERNAL: This is internal to the unit of work and should not be called otherwise.- Overrides:
- basicRollbackTransactionin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
connectpublic void connect(org.eclipse.persistence.internal.databaseaccess.Accessor accessor) throws DatabaseExceptionINTERNAL: Connect the session only (this must be the write connection as the read is shared).- Throws:
- DatabaseException
 
 - 
containsQuerypublic boolean containsQuery(java.lang.String queryName) INTERNAL: Was PUBLIC: customer will be redirected toSession. Return true if the pre-defined query is defined on the session.- Specified by:
- containsQueryin interface- Session
- Overrides:
- containsQueryin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
disconnectpublic void disconnect(org.eclipse.persistence.internal.databaseaccess.Accessor accessor) throws DatabaseExceptionINTERNAL: Disconnect the accessor only (this must be the write connection as the read is shared).- Throws:
- DatabaseException
 
 - 
executeCallpublic java.lang.Object executeCall(Call call, org.eclipse.persistence.internal.sessions.AbstractRecord translationRow, DatabaseQuery query) throws DatabaseException INTERNAL: Execute the call on the correct connection accessor. Outside of a transaction the server session's read connection pool is used. In side a transaction, or for exclusive sessions the write connection is used. For partitioning there may be multiple write connections.- Overrides:
- executeCallin class- org.eclipse.persistence.internal.sessions.AbstractSession
- Throws:
- DatabaseException
 
 - 
releaseConnectionAfterCallpublic void releaseConnectionAfterCall(DatabaseQuery query) INTERNAL: Release (if required) connection after call.- Overrides:
- releaseConnectionAfterCallin class- org.eclipse.persistence.internal.sessions.AbstractSession
- Parameters:
- query-
 
 - 
getAccessorspublic java.util.Collection<org.eclipse.persistence.internal.databaseaccess.Accessor> getAccessors() INTERNAL: Return the write connections if in a transaction. These may be empty/null until the first query has been executed inside the transaction. This should only be called within a transaction. If outside of a transaction it will return null (unless using an exclusive connection).- Overrides:
- getAccessorsin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
getAccessorpublic org.eclipse.persistence.internal.databaseaccess.Accessor getAccessor() INTERNAL: This should normally not be used, getAccessors() should be used to support partitioning. To maintain backward compatibility, and to support certain cases that required a default accessor, if inside a transaction, then a default connection will be allocated. This is required for sequencing, and JPA connection unwrapping, and ordt mappings. Outside of a transaction, to maintain backward compatibility the server session's accessor will be returned.- Overrides:
- getAccessorin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
getConnectionPolicypublic ConnectionPolicy getConnectionPolicy() ADVANCED: This method will return the connection policy that was used during the acquisition of this client session. The properties within the ConnectionPolicy may be used when acquiring an exclusive connection for an IsolatedSession.
 - 
getDescriptorspublic java.util.Map<java.lang.Class,ClassDescriptor> getDescriptors() ADVANCED: Return all registered descriptors.- Specified by:
- getDescriptorsin interface- CoreSession<ClassDescriptor,Login,org.eclipse.persistence.internal.databaseaccess.Platform,Project,SessionEventManager>
- Specified by:
- getDescriptorsin interface- Session
- Overrides:
- getDescriptorsin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
getParentIdentityMapSessionpublic org.eclipse.persistence.internal.sessions.AbstractSession getParentIdentityMapSession(ClassDescriptor descriptor, boolean canReturnSelf, boolean terminalOnly) INTERNAL: Returns the appropriate IdentityMap session for this descriptor. Sessions can be chained and each session can have its own Cache/IdentityMap. Entities can be stored at different levels based on Cache Isolation. This method will return the correct Session for a particular Entity class based on the Isolation Level and the attributes provided.- Overrides:
- getParentIdentityMapSessionin class- org.eclipse.persistence.internal.sessions.AbstractSession
- Parameters:
- canReturnSelf- true when method calls itself. If the path starting at- thisis acceptable. Sometimes true if want to move to the first valid session, i.e. executing on ClientSession when really should be on ServerSession.
- terminalOnly- return the last session in the chain where the Enitity is stored.
- Returns:
- Session with the required IdentityMap
 
 - 
getPropertypublic java.lang.Object getProperty(java.lang.String name) Search for and return the user defined property from this client session, if it not found then search for the property from parent.- Specified by:
- getPropertyin interface- Session
- Overrides:
- getPropertyin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
getExecutionSessionpublic org.eclipse.persistence.internal.sessions.AbstractSession getExecutionSession(DatabaseQuery query) INTERNAL: Gets the session which this query will be executed on. Generally will be called immediately before the call is translated, which is immediately before session.executeCall.Since the execution session also knows the correct datasource platform to execute on, it is often used in the mappings where the platform is needed for type conversion, or where calls are translated. Is also the session with the accessor. Will return a ClientSession if it is in transaction and has a write connection. - Overrides:
- getExecutionSessionin class- org.eclipse.persistence.internal.sessions.AbstractSession
- Parameters:
- query- may store session name or reference class for brokers case
- Returns:
- a session with a live accessor
 
 - 
getParentpublic ServerSession getParent() INTERNAL: Return the parent. This is a server session.- Overrides:
- getParentin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
getQuerypublic DatabaseQuery getQuery(java.lang.String name) INTERNAL: Was PUBLIC: customer will be redirected toSession. Return the query from the session pre-defined queries with the given name. This allows for common queries to be pre-defined, reused and executed by name.
 - 
getQuerypublic DatabaseQuery getQuery(java.lang.String name, java.util.Vector args) INTERNAL:- Overrides:
- getQueryin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
initializeSequencingpublic void initializeSequencing() INTERNAL: was ADVANCED: Creates sequencing object for the session. Typically there is no need for the user to call this method - it is called from the constructor.
 - 
getSequencingpublic org.eclipse.persistence.internal.sequencing.Sequencing getSequencing() INTERNAL: Return the Sequencing object used by the session. Lazy init sequencing to defer from client session creation to improve creation performance.- Overrides:
- getSequencingin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
getServerPlatformpublic ServerPlatform getServerPlatform() INTERNAL: Marked internal as this is not customer API but helper methods for accessing the server platform from within other sessions types (i.e. not DatabaseSession)- Specified by:
- getServerPlatformin interface- Session
- Overrides:
- getServerPlatformin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
getSessionTypeStringpublic java.lang.String getSessionTypeString() INTERNAL: Returns the type of session, its class.Override to hide from the user when they are using an internal subclass of a known class. A user does not need to know that their UnitOfWork is a non-deferred UnitOfWork, or that their ClientSession is an IsolatedClientSession. - Overrides:
- getSessionTypeStringin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
getWriteConnectionspublic java.util.Map<java.lang.String,org.eclipse.persistence.internal.databaseaccess.Accessor> getWriteConnections() INTERNAL: Return the map of write connections. Multiple connections can be used for data partitioning and replication. The connections are keyed by connection pool name.
 - 
getWriteConnectionpublic org.eclipse.persistence.internal.databaseaccess.Accessor getWriteConnection() INTERNAL: Return the connection to be used for database modification.
 - 
hasWriteConnectionpublic boolean hasWriteConnection() INTERNAL: Return if this session has been connected.
 - 
initializeIdentityMapAccessorpublic void initializeIdentityMapAccessor() INTERNAL: Set up the IdentityMapManager. This method allows subclasses of Session to override the default IdentityMapManager functionality.- Overrides:
- initializeIdentityMapAccessorin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
isActivepublic boolean isActive() INTERNAL: Was PUBLIC: customer will be redirected toSession. Return if the client session is active (has not been released).
 - 
isClientSessionpublic boolean isClientSession() INTERNAL: Return if this session is a client session.- Specified by:
- isClientSessionin interface- Session
- Overrides:
- isClientSessionin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
isConnectedpublic boolean isConnected() INTERNAL: Was PUBLIC: customer will be redirected toSession. Return if this session has been connected to the database.- Specified by:
- isConnectedin interface- Session
- Overrides:
- isConnectedin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
releasepublic void release() throws DatabaseExceptionINTERNAL: Was PUBLIC: customer will be redirected toSession. Release the client session. This releases the client session back to it server. Normally this will logout of the client session's connection, and allow the client session to garbage collect.- Specified by:
- releasein interface- Session
- Overrides:
- releasein class- org.eclipse.persistence.internal.sessions.AbstractSession
- Throws:
- DatabaseException
 
 - 
retryQuerypublic java.lang.Object retryQuery(DatabaseQuery query, org.eclipse.persistence.internal.sessions.AbstractRecord row, DatabaseException databaseException, int retryCount, org.eclipse.persistence.internal.sessions.AbstractSession executionSession) INTERNAL: A query execution failed due to an invalid query. Re-connect and retry the query.- Overrides:
- retryQueryin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
releaseWriteConnectionprotected void releaseWriteConnection() INTERNAL: This is internal to the unit of work and should not be called otherwise.
 - 
setConnectionPolicypublic void setConnectionPolicy(ConnectionPolicy connectionPolicy) INTERNAL: Set the connection policy.
 - 
setIsActiveprotected void setIsActive(boolean isActive) INTERNAL: Set if the client session is active (has not been released).
 - 
setParentprotected void setParent(ServerSession parent) INTERNAL: Set the parent. This is a server session.
 - 
addWriteConnectionpublic org.eclipse.persistence.internal.databaseaccess.Accessor addWriteConnection(java.lang.String poolName, org.eclipse.persistence.internal.databaseaccess.Accessor writeConnection)INTERNAL: Add the connection to the client session. Multiple connections are supported to allow data partitioning and replication. The accessor is returned, as if detected to be dead it may be replaced.
 - 
retryTransactionpublic DatabaseException retryTransaction(org.eclipse.persistence.internal.databaseaccess.Accessor writeConnection, DatabaseException databaseException, int retryCount, org.eclipse.persistence.internal.sessions.AbstractSession executionSession) INTERNAL: A begin transaction failed. Re-connect and retry the begin transaction.- Overrides:
- retryTransactionin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
setWriteConnectionspublic void setWriteConnections(java.util.Map<java.lang.String,org.eclipse.persistence.internal.databaseaccess.Accessor> writeConnections) INTERNAL: Set the connection to be used for database modification.
 - 
setWriteConnectionpublic void setWriteConnection(org.eclipse.persistence.internal.databaseaccess.Accessor writeConnection) INTERNAL: Set the connection to be used for database modification.
 - 
toStringpublic java.lang.String toString() INTERNAL: Print the connection status with the session.- Overrides:
- toStringin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
getCommandManagerpublic CommandManager getCommandManager() INTERNAL: Return the manager that allows this processor to receive or propagate commands from/to TopLink cluster- Specified by:
- getCommandManagerin interface- CommandProcessor
- Overrides:
- getCommandManagerin class- org.eclipse.persistence.internal.sessions.AbstractSession
- Returns:
- a remote command manager
- See Also:
- CommandManager
 
 - 
shouldPropagateChangespublic boolean shouldPropagateChanges() INTERNAL: Return whether changes should be propagated to TopLink cluster. This is one of the required cache synchronization setting- Overrides:
- shouldPropagateChangesin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
releaseReadConnectionpublic void releaseReadConnection(org.eclipse.persistence.internal.databaseaccess.Accessor connection) INTERNAL: Release the cursor query's connection.- Overrides:
- releaseReadConnectionin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 - 
isExclusiveConnectionRequiredpublic boolean isExclusiveConnectionRequired() INTERNAL: This method is called in case externalConnectionPooling is used. If returns true, accessor used by the session keeps its connection open until released by the session.- Overrides:
- isExclusiveConnectionRequiredin class- org.eclipse.persistence.internal.sessions.AbstractSession
 
 
- 
 
-