public class DatasourceConnectionProviderImpl extends Object implements ConnectionProvider, Configurable, Stoppable
ConnectionProvider
that manages connections from an underlying DataSource
.
The DataSource
to use may be specified by either:setDataSource(javax.sql.DataSource)
DataSource
instance using the AvailableSettings.DATASOURCE
config propertyDataSource
can be found via AvailableSettings.DATASOURCE
config propertyConstructor and Description |
---|
DatasourceConnectionProviderImpl() |
Modifier and Type | Method and Description |
---|---|
void |
closeConnection(Connection connection)
Release a connection from Hibernate use.
|
void |
configure(Map configValues)
Configure the service.
|
Connection |
getConnection()
Obtains a connection for Hibernate use according to the underlying strategy of this provider.
|
DataSource |
getDataSource() |
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 notification
|
boolean |
supportsAggressiveRelease()
Does this connection provider support aggressive release of JDBC
connections and re-acquisition of those connections (if need be) later?
This is used in conjunction with
AvailableSettings.RELEASE_CONNECTIONS
to aggressively release JDBC connections. |
<T> T |
unwrap(Class<T> unwrapType)
Unproxy the service proxy
|
public DataSource getDataSource()
public void setDataSource(DataSource dataSource)
public void setJndiService(JndiService jndiService)
public boolean isUnwrappableAs(Class unwrapType)
Wrapped
isUnwrappableAs
in interface Wrapped
unwrapType
- The type to check.public <T> T unwrap(Class<T> unwrapType)
Wrapped
public void configure(Map configValues)
Configurable
configure
in interface Configurable
configValues
- The configuration properties.public void stop()
Stoppable
public Connection getConnection() throws SQLException
ConnectionProvider
getConnection
in interface ConnectionProvider
SQLException
- Indicates a problem opening a connectionpublic void closeConnection(Connection connection) throws SQLException
ConnectionProvider
closeConnection
in interface ConnectionProvider
connection
- The JDBC connection to releaseSQLException
- Indicates a problem closing the connectionpublic boolean supportsAggressiveRelease()
ConnectionProvider
AvailableSettings.RELEASE_CONNECTIONS
to aggressively release JDBC connections. However, the configured ConnectionProvider
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.supportsAggressiveRelease
in interface ConnectionProvider
true
if aggressive releasing is supported; false
otherwise.Copyright © 2001-2015 Red Hat, Inc. All Rights Reserved.