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 java.lang.String | SAVEPOINT_NAME_PREFIXPrefix for savepoint names. | 
| Constructor and Description | 
|---|
| ConnectionHolder(java.sql.Connection connection)Create a new ConnectionHolder for the given JDBC Connection,
 wrapping it with a  SimpleConnectionHandle,
 assuming that there is no ongoing transaction. | 
| ConnectionHolder(java.sql.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. | 
| java.sql.Savepoint | createSavepoint()Create a new JDBC 3.0 Savepoint for the current Connection,
 using generated savepoint names that are unique for the Connection. | 
| java.sql.Connection | getConnection()Return the current Connection held by this ConnectionHolder. | 
| ConnectionHandle | getConnectionHandle() | 
| protected boolean | hasConnection() | 
| protected boolean | isTransactionActive() | 
| void | released()Releases the current Connection held by this ConnectionHolder. | 
| protected void | setConnection(java.sql.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, setTimeout, setTimeoutInMillis, unboundpublic static final java.lang.String SAVEPOINT_NAME_PREFIX
public ConnectionHolder(ConnectionHandle connectionHandle)
connectionHandle - the ConnectionHandle to holdpublic ConnectionHolder(java.sql.Connection connection)
SimpleConnectionHandle,
 assuming that there is no ongoing transaction.connection - the JDBC Connection to holdSimpleConnectionHandle, 
ConnectionHolder(java.sql.Connection, boolean)public ConnectionHolder(java.sql.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)
transactionActive - Whether a transaction is activeDataSourceTransactionManagerprotected boolean isTransactionActive()
protected void setConnection(@Nullable
                             java.sql.Connection connection)
null.
 Used for releasing the Connection on suspend (with a null
 argument) and setting a fresh Connection on resume.
connection - The connectionpublic java.sql.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 java.sql.SQLException
java.sql.SQLException - if thrown by the JDBC driverpublic java.sql.Savepoint createSavepoint()
                                   throws java.sql.SQLException
java.sql.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