public class ConnectionHolder extends ResourceHolderSupport
Connection.
 DataSourceTransactionManager binds instances of this class
 to the thread, for a specific DataSource.
 Inherits rollback-only support for nested JDBC transactions and reference count functionality from the base class.
Note: This is an SPI class, not intended to be used by applications.
DataSourceTransactionManager, 
DataSourceUtils| Modifier and Type | Field and Description | 
|---|---|
| static String | SAVEPOINT_NAME_PREFIXPrefix for savepoint names. | 
| Constructor and Description | 
|---|
| ConnectionHolder(Connection connection)Create a new ConnectionHolder for the given JDBC Connection,
 wrapping it with a  SimpleConnectionHandle,
 assuming that there is no ongoing transaction. | 
| ConnectionHolder(Connection connection,
                boolean transactionActive)Create a new ConnectionHolder for the given JDBC Connection,
 wrapping it with a  SimpleConnectionHandle. | 
| ConnectionHolder(ConnectionHandle connectionHandle)Create a new ConnectionHolder for the given ConnectionHandle. | 
| Modifier and Type | Method and Description | 
|---|---|
| void | clear()Clear the transactional state of this resource holder. | 
| Savepoint | createSavepoint()Create a new JDBC 3.0 Savepoint for the current Connection,
 using generated savepoint names that are unique for the Connection. | 
| Connection | getConnection()Return the current Connection held by this ConnectionHolder. | 
| ConnectionHandle | getConnectionHandle()Return the ConnectionHandle held by this ConnectionHolder. | 
| protected boolean | hasConnection()Return whether this holder currently has a Connection. | 
| protected boolean | isTransactionActive()Return whether this holder represents an active, JDBC-managed transaction. | 
| void | released()Releases the current Connection held by this ConnectionHolder. | 
| protected void | setConnection(Connection connection)Override the existing Connection handle with the given Connection. | 
| protected void | setTransactionActive(boolean transactionActive)Set whether this holder represents an active, JDBC-managed transaction. | 
| boolean | supportsSavepoints()Return whether JDBC 3.0 Savepoints are supported. | 
getDeadline, getTimeToLiveInMillis, getTimeToLiveInSeconds, hasTimeout, isOpen, isRollbackOnly, isSynchronizedWithTransaction, isVoid, requested, reset, resetRollbackOnly, setRollbackOnly, setSynchronizedWithTransaction, setTimeoutInMillis, setTimeoutInSeconds, unboundpublic static final String SAVEPOINT_NAME_PREFIX
public ConnectionHolder(ConnectionHandle connectionHandle)
connectionHandle - the ConnectionHandle to holdpublic ConnectionHolder(Connection connection)
SimpleConnectionHandle,
 assuming that there is no ongoing transaction.connection - the JDBC Connection to holdSimpleConnectionHandle, 
ConnectionHolder(java.sql.Connection, boolean)public ConnectionHolder(Connection connection, boolean transactionActive)
SimpleConnectionHandle.connection - the JDBC Connection to holdtransactionActive - whether the given Connection is involved
 in an ongoing transactionSimpleConnectionHandle@Nullable public ConnectionHandle getConnectionHandle()
protected boolean hasConnection()
protected void setTransactionActive(boolean transactionActive)
DataSourceTransactionManagerprotected boolean isTransactionActive()
protected void setConnection(@Nullable Connection connection)
null.
 Used for releasing the Connection on suspend (with a null
 argument) and setting a fresh Connection on resume.
public Connection getConnection()
This will be the same Connection until released
 gets called on the ConnectionHolder, which will reset the
 held Connection, fetching a new Connection on demand.
ConnectionHandle.getConnection(), 
released()public boolean supportsSavepoints()
                           throws SQLException
SQLException - if thrown by the JDBC driverpublic Savepoint createSavepoint() throws SQLException
SQLException - if thrown by the JDBC driverpublic void released()
This is necessary for ConnectionHandles that expect "Connection borrowing", where each returned Connection is only temporarily leased and needs to be returned once the data operation is done, to make the Connection available for other operations within the same transaction.
released in class ResourceHolderSupportpublic void clear()
ResourceHolderSupportclear in class ResourceHolderSupport