Class DatasourceConnectionProviderImpl
java.lang.Object
org.hibernate.engine.jdbc.connections.internal.DatasourceConnectionProviderImpl
- All Implemented Interfaces:
Serializable
,ConnectionProvider
,Service
,Configurable
,Stoppable
,Wrapped
public class DatasourceConnectionProviderImpl
extends Object
implements ConnectionProvider, Configurable, Stoppable
A
ConnectionProvider
that manages connections from an underlying DataSource
.
The DataSource
to use may be specified by either:
- injection using
setDataSource(javax.sql.DataSource)
, - passing the
DataSource
instance using "hibernate.connection.datasource", "jakarta.persistence.jtaDataSource", or "jakarta.persistence.nonJtaDataSource", or - declaring the JNDI name under which the
DataSource
is found via "hibernate.connection.datasource", "jakarta.persistence.jtaDataSource", or "jakarta.persistence.nonJtaDataSource".
- See Also:
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoid
closeConnection
(Connection connection) Release a connection from Hibernate use.void
Configure the service.Obtains a connection for Hibernate use according to the underlying strategy of this provider.getDatabaseConnectionInfo
(Dialect dialect) boolean
isUnwrappableAs
(Class<?> unwrapType) Can this wrapped service be unwrapped as the indicated type?void
setDataSource
(DataSource dataSource) void
setJndiService
(JndiService jndiService) void
stop()
Stop phase notificationboolean
Does this connection provider support aggressive release of JDBC connections and later re-acquisition of those connections if needed?<T> T
Unproxy the service proxy
-
Constructor Details
-
DatasourceConnectionProviderImpl
public DatasourceConnectionProviderImpl()
-
-
Method Details
-
getDataSource
-
setDataSource
-
setJndiService
-
isUnwrappableAs
Description copied from interface:Wrapped
Can this wrapped service be unwrapped as the indicated type?- Specified by:
isUnwrappableAs
in interfaceWrapped
- Parameters:
unwrapType
- The type to check.- Returns:
- True/false.
-
unwrap
Description copied from interface:Wrapped
Unproxy the service proxy -
configure
Description copied from interface:Configurable
Configure the service.- Specified by:
configure
in interfaceConfigurable
- Parameters:
configValues
- The configuration properties.
-
stop
public void stop()Description copied from interface:Stoppable
Stop phase notification -
getConnection
Description copied from interface:ConnectionProvider
Obtains a connection for Hibernate use according to the underlying strategy of this provider.- Specified by:
getConnection
in interfaceConnectionProvider
- Returns:
- The obtained JDBC connection
- Throws:
SQLException
- Indicates a problem opening a connection
-
closeConnection
Description copied from interface:ConnectionProvider
Release a connection from Hibernate use.- Specified by:
closeConnection
in interfaceConnectionProvider
- Parameters:
connection
- The JDBC connection to release- Throws:
SQLException
- Indicates a problem closing the connection
-
supportsAggressiveRelease
public boolean supportsAggressiveRelease()Description copied from interface:ConnectionProvider
Does this connection provider support aggressive release of JDBC connections and later re-acquisition of those connections if needed?This is used in conjunction with
ConnectionReleaseMode.AFTER_STATEMENT
to aggressively release JDBC connections. However, the configuredConnectionProvider
must support re-acquisition of the same underlying connection for that semantic to work.Typically, this is only true in managed environments where a container tracks connections by transaction or thread.
Note that JTA semantic depends on the fact that the underlying connection provider does support aggressive release.
- Specified by:
supportsAggressiveRelease
in interfaceConnectionProvider
- Returns:
true
if aggressive releasing is supported;false
otherwise.
-
getDatabaseConnectionInfo
- Specified by:
getDatabaseConnectionInfo
in interfaceConnectionProvider
-