java.lang.Object | ||
↳ | org.springframework.orm.hibernate3.HibernateAccessor | |
↳ | org.springframework.orm.hibernate3.support.OpenSessionInViewInterceptor |
Spring web request interceptor that binds a Hibernate Session
to the
thread for the entire processing of the request.
This class is a concrete expression of the "Open Session in View" pattern, which is a pattern that allows for the lazy loading of associations in web views despite the original transactions already being completed.
This interceptor makes Hibernate Sessions
available via the current
thread, which will be autodetected by transaction managers. It is suitable for
service layer transactions via
HibernateTransactionManager
or
JtaTransactionManager
as well as for
non-transactional execution (if configured appropriately).
NOTE: This interceptor will by default not flush the Hibernate
Session
, with the flush mode being set to FlushMode.NEVER
.
It assumes that it will be used in combination with service layer transactions
that handle the flushing: the active transaction manager will temporarily change
the flush mode to FlushMode.AUTO
during a read-write transaction,
with the flush mode reset to FlushMode.NEVER
at the end of each
transaction. If you intend to use this interceptor without transactions, consider
changing the default flush mode (through the
"flushMode"
property).
In contrast to OpenSessionInViewFilter
, this interceptor is
configured in a Spring application context and can thus take advantage of bean
wiring. It inherits common Hibernate configuration properties from
HibernateAccessor
,
to be configured in a bean definition.
WARNING: Applying this interceptor to existing logic can cause issues
that have not appeared before, through the use of a single Hibernate
Session
for the processing of an entire request. In particular, the
reassociation of persistent objects with a Hibernate Session
has to
occur at the very beginning of request processing, to avoid clashes with already
loaded instances of the same objects.
Alternatively, turn this interceptor into deferred close mode, by specifying "singleSession"="false": It will not use a single session per request then, but rather let each data access operation or transaction use its own session (as would be the case without Open Session in View). Each of those sessions will be registered for deferred close though, which will actually be processed at request completion.
A single session per request allows for the most efficient first-level caching,
but can cause side effects, for example on saveOrUpdate
or when
continuing after a rolled-back transaction. The deferred close strategy is as safe
as no Open Session in View in that respect, while still allowing for lazy loading
in views (but not providing a first-level cache for the entire request).
Constants | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
String | PARTICIPATE_SUFFIX | Suffix that gets appended to the SessionFactory
toString() representation for the "participate in existing
session handling" request attribute. |
[Expand]
Inherited Constants | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
From class
org.springframework.orm.hibernate3.HibernateAccessor
|
[Expand]
Inherited Fields | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
From class
org.springframework.orm.hibernate3.HibernateAccessor
|
Public Constructors | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Create a new
OpenSessionInViewInterceptor ,
turning the default flushMode to FLUSH_NEVER . |
Public Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Unbind the Hibernate
Session from the thread and close it (in
single session mode), or process deferred close for all sessions that have
been opened during the current request (in deferred close mode). | |||||||||||
Flush the Hibernate
Session before view rendering, if necessary. | |||||||||||
Open a new Hibernate
Session according to the settings of this
HibernateAccessor and bind it to the thread via the
TransactionSynchronizationManager . | |||||||||||
Set whether to use a single session for each request.
|
Protected Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Return the name of the request attribute that identifies that a request is
already intercepted.
| |||||||||||
Return whether to use a single session for each request.
|
[Expand]
Inherited Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
From class
org.springframework.orm.hibernate3.HibernateAccessor
| |||||||||||
From class
java.lang.Object
| |||||||||||
From interface
org.springframework.beans.factory.BeanFactoryAware
| |||||||||||
From interface
org.springframework.beans.factory.InitializingBean
| |||||||||||
From interface
org.springframework.web.context.request.WebRequestInterceptor
|
Suffix that gets appended to the SessionFactory
toString()
representation for the "participate in existing
session handling" request attribute.
Create a new OpenSessionInViewInterceptor
,
turning the default flushMode to FLUSH_NEVER
.
Unbind the Hibernate Session
from the thread and close it (in
single session mode), or process deferred close for all sessions that have
been opened during the current request (in deferred close mode).
request | the current web request |
---|---|
ex | exception thrown on handler execution, if any |
DataAccessException |
---|
Flush the Hibernate Session
before view rendering, if necessary.
Note that this just applies in single session mode
!
The default is FLUSH_NEVER
to avoid this extra flushing,
assuming that service layer transactions have flushed their changes on commit.
request | the current web request |
---|---|
model | the map of model objects that will be exposed to the view
(may be null ). Can be used to analyze the exposed model
and/or to add further model attributes, if desired. |
DataAccessException |
---|
Open a new Hibernate Session
according to the settings of this
HibernateAccessor
and bind it to the thread via the
TransactionSynchronizationManager
.
request | the current web request |
---|
DataAccessException |
---|
Set whether to use a single session for each request. Default is "true".
If set to false, each data access operation or transaction will use its own session (like without Open Session in View). Each of those sessions will be registered for deferred close, though, actually processed at request completion.
Return the name of the request attribute that identifies that a request is already intercepted.
The default implementation takes the toString()
representation
of the SessionFactory
instance and appends PARTICIPATE_SUFFIX
.
Return whether to use a single session for each request.