public class IsolationLevelDataSourceAdapter extends UserCredentialsDataSourceAdapter
DataSource
, applying the current
Spring transaction's isolation level (and potentially specified user credentials)
to every getConnection
call. Also applies the read-only flag,
if specified.
Can be used to proxy a target JNDI DataSource that does not have the desired isolation level (and user credentials) configured. Client code can work with this DataSource as usual, not worrying about such settings.
Inherits the capability to apply specific user credentials from its superclass
UserCredentialsDataSourceAdapter
; see the latter's javadoc for details
on that functionality (e.g. UserCredentialsDataSourceAdapter.setCredentialsForCurrentThread(java.lang.String, java.lang.String)
).
WARNING: This adapter simply calls
Connection.setTransactionIsolation(int)
and/or
Connection.setReadOnly(boolean)
for every Connection obtained from it.
It does, however, not reset those settings; it rather expects the target
DataSource to perform such resetting as part of its connection pool handling.
Make sure that the target DataSource properly cleans up such transaction state.
setIsolationLevel(int)
,
setIsolationLevelName(java.lang.String)
,
UserCredentialsDataSourceAdapter.setUsername(java.lang.String)
,
UserCredentialsDataSourceAdapter.setPassword(java.lang.String)
Constructor and Description |
---|
IsolationLevelDataSourceAdapter() |
Modifier and Type | Method and Description |
---|---|
protected java.sql.Connection |
doGetConnection(java.lang.String username,
java.lang.String password)
Applies the current isolation level value and read-only flag
to the returned Connection.
|
protected java.lang.Integer |
getCurrentIsolationLevel()
Determine the current isolation level: either the transaction's
isolation level or a statically defined isolation level.
|
protected java.lang.Boolean |
getCurrentReadOnlyFlag()
Determine the current read-only flag: by default,
the transaction's read-only hint.
|
protected java.lang.Integer |
getIsolationLevel()
Return the statically specified isolation level,
or
null if none. |
void |
setIsolationLevel(int isolationLevel)
Specify the default isolation level to use for Connection retrieval,
according to the JDBC
Connection constants
(equivalent to the corresponding Spring
TransactionDefinition constants). |
void |
setIsolationLevelName(java.lang.String constantName)
Set the default isolation level by the name of the corresponding constant
in
TransactionDefinition , e.g. |
getConnection, getConnection, removeCredentialsFromCurrentThread, setCredentialsForCurrentThread, setPassword, setUsername
afterPropertiesSet, getLoginTimeout, getLogWriter, getParentLogger, getTargetDataSource, isWrapperFor, setLoginTimeout, setLogWriter, setTargetDataSource, unwrap
public final void setIsolationLevelName(java.lang.String constantName) throws java.lang.IllegalArgumentException
TransactionDefinition
, e.g.
"ISOLATION_SERIALIZABLE".
If not specified, the target DataSource's default will be used. Note that a transaction-specific isolation value will always override any isolation setting specified at the DataSource level.
constantName
- name of the constantjava.lang.IllegalArgumentException
TransactionDefinition.ISOLATION_READ_UNCOMMITTED
,
TransactionDefinition.ISOLATION_READ_COMMITTED
,
TransactionDefinition.ISOLATION_REPEATABLE_READ
,
TransactionDefinition.ISOLATION_SERIALIZABLE
,
setIsolationLevel(int)
public void setIsolationLevel(int isolationLevel)
Connection
constants
(equivalent to the corresponding Spring
TransactionDefinition
constants).
If not specified, the target DataSource's default will be used. Note that a transaction-specific isolation value will always override any isolation setting specified at the DataSource level.
Connection.TRANSACTION_READ_UNCOMMITTED
,
Connection.TRANSACTION_READ_COMMITTED
,
Connection.TRANSACTION_REPEATABLE_READ
,
Connection.TRANSACTION_SERIALIZABLE
,
TransactionDefinition.ISOLATION_READ_UNCOMMITTED
,
TransactionDefinition.ISOLATION_READ_COMMITTED
,
TransactionDefinition.ISOLATION_REPEATABLE_READ
,
TransactionDefinition.ISOLATION_SERIALIZABLE
,
TransactionDefinition.getIsolationLevel()
,
TransactionSynchronizationManager.getCurrentTransactionIsolationLevel()
protected java.lang.Integer getIsolationLevel()
null
if none.protected java.sql.Connection doGetConnection(java.lang.String username, java.lang.String password) throws java.sql.SQLException
doGetConnection
in class UserCredentialsDataSourceAdapter
username
- the username to usepassword
- the password to usejava.sql.SQLException
getCurrentIsolationLevel()
,
getCurrentReadOnlyFlag()
protected java.lang.Integer getCurrentIsolationLevel()
null
if noneTransactionSynchronizationManager.getCurrentTransactionIsolationLevel()
,
setIsolationLevel(int)
protected java.lang.Boolean getCurrentReadOnlyFlag()
TransactionSynchronizationManager.isCurrentTransactionReadOnly()