|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.springframework.orm.hibernate3.SessionFactoryUtils
public abstract class SessionFactoryUtils
Helper class featuring methods for Hibernate Session handling, allowing for reuse of Hibernate Session instances within transactions.
Supports synchronization with both Spring-managed JTA transactions
(i.e. JtaTransactionManager) and non-Spring JTA transactions (i.e. plain JTA
or EJB CMT). See the getSession
version with all parameters
for details.
Used internally by HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. Can also be used directly in application code, e.g. in combination with HibernateInterceptor.
HibernateTemplate
,
HibernateInterceptor
,
HibernateTransactionManager
,
JtaTransactionManager
Field Summary | |
---|---|
static int |
SESSION_SYNCHRONIZATION_ORDER
Order value for TransactionSynchronization objects that clean up Hibernate Sessions. |
Constructor Summary | |
---|---|
SessionFactoryUtils()
|
Method Summary | |
---|---|
static void |
applyTransactionTimeout(org.hibernate.Criteria criteria,
org.hibernate.SessionFactory sessionFactory)
Apply the current transaction timeout, if any, to the given Hibernate Criteria object. |
static void |
applyTransactionTimeout(org.hibernate.Query query,
org.hibernate.SessionFactory sessionFactory)
Apply the current transaction timeout, if any, to the given Hibernate Query object. |
static void |
closeSessionIfNecessary(org.hibernate.Session session,
org.hibernate.SessionFactory sessionFactory)
Deprecated. in favor of releaseSession |
static DataAccessException |
convertHibernateAccessException(org.hibernate.HibernateException ex)
Convert the given HibernateException to an appropriate exception from the org.springframework.dao hierarchy. |
static org.hibernate.Session |
doGetSession(org.hibernate.SessionFactory sessionFactory,
boolean allowCreate)
Get a Hibernate Session for the given SessionFactory. |
static DataSource |
getDataSource(org.hibernate.SessionFactory sessionFactory)
Determine the DataSource of the given SessionFactory. |
static TransactionManager |
getJtaTransactionManager(org.hibernate.SessionFactory sessionFactory,
org.hibernate.Session session)
Try to retrieve the JTA TransactionManager from the given SessionFactory and/or Session. |
static org.hibernate.Session |
getNewSession(org.hibernate.SessionFactory sessionFactory)
Get a new Hibernate Session from the given SessionFactory. |
static org.hibernate.Session |
getNewSession(org.hibernate.SessionFactory sessionFactory,
org.hibernate.Interceptor entityInterceptor)
Get a new Hibernate Session from the given SessionFactory. |
static org.hibernate.Session |
getSession(org.hibernate.SessionFactory sessionFactory,
boolean allowCreate)
Get a Hibernate Session for the given SessionFactory. |
static org.hibernate.Session |
getSession(org.hibernate.SessionFactory sessionFactory,
org.hibernate.Interceptor entityInterceptor,
SQLExceptionTranslator jdbcExceptionTranslator)
Get a Hibernate Session for the given SessionFactory. |
static void |
initDeferredClose(org.hibernate.SessionFactory sessionFactory)
Initialize deferred close for the current thread and the given SessionFactory. |
static boolean |
isDeferredCloseActive(org.hibernate.SessionFactory sessionFactory)
Return if deferred close is active for the current thread and the given SessionFactory. |
static boolean |
isSessionTransactional(org.hibernate.Session session,
org.hibernate.SessionFactory sessionFactory)
Return whether the given Hibernate Session is transactional, that is, bound to the current thread by Spring's transaction facilities. |
static SQLExceptionTranslator |
newJdbcExceptionTranslator(org.hibernate.SessionFactory sessionFactory)
Create an appropriate SQLExceptionTranslator for the given SessionFactory. |
static void |
processDeferredClose(org.hibernate.SessionFactory sessionFactory)
Process Sessions that have been registered for deferred close for the given SessionFactory. |
static void |
releaseSession(org.hibernate.Session session,
org.hibernate.SessionFactory sessionFactory)
Close the given Session, created via the given factory, if it is not managed externally (i.e. not bound to the thread). |
static String |
toString(org.hibernate.Session session)
Stringify the given Session for debug logging. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
public static final int SESSION_SYNCHRONIZATION_ORDER
DataSourceUtils.CONNECTION_SYNCHRONIZATION_ORDER
,
Constant Field ValuesConstructor Detail |
---|
public SessionFactoryUtils()
Method Detail |
---|
public static DataSource getDataSource(org.hibernate.SessionFactory sessionFactory)
sessionFactory
- the SessionFactory to check
null
if none foundSessionFactoryImplementor.getConnectionProvider()
,
LocalDataSourceConnectionProvider
public static SQLExceptionTranslator newJdbcExceptionTranslator(org.hibernate.SessionFactory sessionFactory)
sessionFactory
- the SessionFactory to create the translator for
getDataSource(org.hibernate.SessionFactory)
,
SQLErrorCodeSQLExceptionTranslator
,
SQLStateSQLExceptionTranslator
public static TransactionManager getJtaTransactionManager(org.hibernate.SessionFactory sessionFactory, org.hibernate.Session session)
sessionFactory
- Hibernate SessionFactorysession
- Hibernate Session (can also be null
)
TransactionManager
,
SessionFactoryImplementor.getTransactionManager()
,
Session.getSessionFactory()
,
SessionFactoryImpl
,
org.hibernate.jca.JCASessionFactoryImpl
public static org.hibernate.Session getSession(org.hibernate.SessionFactory sessionFactory, boolean allowCreate) throws DataAccessResourceFailureException, IllegalStateException
This is the getSession
method used by typical data access code,
in combination with releaseSession
called when done with
the Session. Note that HibernateTemplate allows to write data access code
without caring about such resource handling.
Supports synchronization with both Spring-managed JTA transactions
(i.e. JtaTransactionManager) and non-Spring JTA transactions (i.e. plain JTA
or EJB CMT). See the getSession
version with all parameters
for details.
sessionFactory
- Hibernate SessionFactory to create the session withallowCreate
- if a non-transactional Session should be created when no
transactional Session can be found for the current thread
DataAccessResourceFailureException
- if the Session couldn't be created
IllegalStateException
- if no thread-bound Session found and allowCreate falsegetSession(SessionFactory, Interceptor, SQLExceptionTranslator)
,
releaseSession(org.hibernate.Session, org.hibernate.SessionFactory)
,
HibernateTemplate
public static org.hibernate.Session getSession(org.hibernate.SessionFactory sessionFactory, org.hibernate.Interceptor entityInterceptor, SQLExceptionTranslator jdbcExceptionTranslator) throws DataAccessResourceFailureException
Supports synchronization with Spring-managed JTA transactions (i.e. JtaTransactionManager) via TransactionSynchronizationManager, to allow for transaction-scoped Hibernate Sessions and proper transactional handling of the JVM-level cache.
Supports synchronization with non-Spring JTA transactions (i.e. plain JTA or EJB CMT) via TransactionSynchronizationManager, to allow for transaction-scoped Hibernate Sessions without JtaTransactionManager. This only applies when a JTA TransactionManagerLookup is specified in the Hibernate configuration.
Supports setting a Session-level Hibernate entity interceptor that allows to inspect and change property values before writing to and reading from the database. Such an interceptor can also be set at the SessionFactory level (i.e. on LocalSessionFactoryBean), on HibernateTransactionManager, or on HibernateInterceptor/HibernateTemplate.
sessionFactory
- Hibernate SessionFactory to create the session withentityInterceptor
- Hibernate entity interceptor, or null
if nonejdbcExceptionTranslator
- SQLExcepionTranslator to use for flushing the
Session on transaction synchronization (can be null
; only used when actually
registering a transaction synchronization)
DataAccessResourceFailureException
- if the Session couldn't be createdLocalSessionFactoryBean.setEntityInterceptor(org.hibernate.Interceptor)
,
HibernateAccessor.setEntityInterceptor(org.hibernate.Interceptor)
,
HibernateAccessor.setEntityInterceptor(org.hibernate.Interceptor)
,
HibernateTransactionManager
,
JtaTransactionManager
,
TransactionSynchronizationManager
public static org.hibernate.Session doGetSession(org.hibernate.SessionFactory sessionFactory, boolean allowCreate) throws org.hibernate.HibernateException, IllegalStateException
Supports synchronization with both Spring-managed JTA transactions
(i.e. JtaTransactionManager) and non-Spring JTA transactions (i.e. plain JTA
or EJB CMT). See the getSession
version with all parameters
for details.
Throws the original HibernateException, in contrast to getSession
.
sessionFactory
- Hibernate SessionFactory to create the session withallowCreate
- if a non-transactional Session should be created when no
transactional Session can be found for the current thread
org.hibernate.HibernateException
- if the Session couldn't be created
IllegalStateException
- if no thread-bound Session found and allowCreate falsegetSession(SessionFactory, Interceptor, SQLExceptionTranslator)
,
releaseSession(org.hibernate.Session, org.hibernate.SessionFactory)
,
HibernateTemplate
public static org.hibernate.Session getNewSession(org.hibernate.SessionFactory sessionFactory)
Within a transaction, this method will create a new Session that shares the transaction's JDBC Connection. More specifically, it will use the same JDBC Connection as the pre-bound Hibernate Session.
sessionFactory
- Hibernate SessionFactory to create the session with
public static org.hibernate.Session getNewSession(org.hibernate.SessionFactory sessionFactory, org.hibernate.Interceptor entityInterceptor)
Within a transaction, this method will create a new Session that shares the transaction's JDBC Connection. More specifically, it will use the same JDBC Connection as the pre-bound Hibernate Session.
sessionFactory
- Hibernate SessionFactory to create the session withentityInterceptor
- Hibernate entity interceptor, or null
if none
public static String toString(org.hibernate.Session session)
Object.toString()
:
the fully qualified class name + "@" + the identity hash code.
The only reason why this is necessary is because Hibernate3's
Session.toString()
implementation is broken (and won't be fixed):
it logs the toString representation of all persistent objects in the Session,
which might lead to ConcurrentModificationExceptions if the persistent objects
in turn refer to the Session (for example, for lazy loading).
session
- the Hibernate Session to stringify
public static boolean isSessionTransactional(org.hibernate.Session session, org.hibernate.SessionFactory sessionFactory)
session
- the Hibernate Session to checksessionFactory
- Hibernate SessionFactory that the Session was created with
(can be null
)
public static void applyTransactionTimeout(org.hibernate.Query query, org.hibernate.SessionFactory sessionFactory)
query
- the Hibernate Query objectsessionFactory
- Hibernate SessionFactory that the Query was created for
(can be null
)Query.setTimeout(int)
public static void applyTransactionTimeout(org.hibernate.Criteria criteria, org.hibernate.SessionFactory sessionFactory)
criteria
- the Hibernate Criteria objectsessionFactory
- Hibernate SessionFactory that the Criteria was created forCriteria.setTimeout(int)
public static DataAccessException convertHibernateAccessException(org.hibernate.HibernateException ex)
org.springframework.dao
hierarchy. Note that it is advisable to
handle JDBCException specifically by using a SQLExceptionTranslator for the
underlying SQLException.
ex
- HibernateException that occured
HibernateAccessor.convertHibernateAccessException(org.hibernate.HibernateException)
,
HibernateAccessor.convertJdbcAccessException(org.hibernate.JDBCException)
,
HibernateTransactionManager.convertHibernateAccessException(org.hibernate.HibernateException)
,
HibernateTransactionManager.convertJdbcAccessException(org.hibernate.JDBCException)
,
JDBCException.getSQLException()
,
SQLExceptionTranslator
public static boolean isDeferredCloseActive(org.hibernate.SessionFactory sessionFactory)
sessionFactory
- the Hibernate SessionFactory to checkpublic static void initDeferredClose(org.hibernate.SessionFactory sessionFactory)
Used by OpenSessionInViewFilter and OpenSessionInViewInterceptor when not configured for a single session.
sessionFactory
- Hibernate SessionFactoryprocessDeferredClose(org.hibernate.SessionFactory)
,
releaseSession(org.hibernate.Session, org.hibernate.SessionFactory)
,
OpenSessionInViewFilter.setSingleSession(boolean)
,
OpenSessionInViewInterceptor.setSingleSession(boolean)
public static void processDeferredClose(org.hibernate.SessionFactory sessionFactory)
sessionFactory
- Hibernate SessionFactoryinitDeferredClose(org.hibernate.SessionFactory)
,
releaseSession(org.hibernate.Session, org.hibernate.SessionFactory)
public static void closeSessionIfNecessary(org.hibernate.Session session, org.hibernate.SessionFactory sessionFactory)
releaseSession(org.hibernate.Session, org.hibernate.SessionFactory)
public static void releaseSession(org.hibernate.Session session, org.hibernate.SessionFactory sessionFactory)
session
- the Hibernate Session to closesessionFactory
- Hibernate SessionFactory that the Session was created with
(can be null
)
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |