Class JTASessionContext
- All Implemented Interfaces:
Serializable,CurrentSessionContext
CurrentSessionContext which scopes the notion
of a current session to a JTA transaction. Because JTA gives us a nice tie-in to clean up after
ourselves, this implementation will generate Sessions as needed, provided a JTA transaction is in
effect. If a session is not already associated with the current JTA transaction at the time
currentSession() is called, a new session is opened and is associated with the JTA
transaction.
Note that the sessions returned from this method are automatically configured with both the
properties "hibernate.transaction.flush_before_completion" and
"hibernate.transaction.auto_close_session" set to true,
meaning that the session will be automatically flushed and closed as part of the lifecycle of the
JTA transaction with which it is associated. Additionally, it will be configured to aggressively
release JDBC connections after each statement is executed. These settings are governed by the
isAutoFlushEnabled(), isAutoCloseEnabled(), and getConnectionHandlingMode()
methods; these are provided (along with the buildOrObtainSession() method) for easier
subclassing for custom JTA-based session tracking logic (like maybe long-session semantics).
- See Also:
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionprotected static classJTA transaction sync used for cleanup of the internal session map. -
Constructor Summary
ConstructorsConstructorDescriptionConstructs a JTASessionContext -
Method Summary
Modifier and TypeMethodDescriptionprotected SessionStrictly provided for subclassing purposes; specifically to allow long-session support.Retrieve the current session according to the scoping defined by this implementation.protected PhysicalConnectionHandlingModeMainly for subclass usage.protected booleanMainly for subclass usage.protected booleanMainly for subclass usage.Methods inherited from class org.hibernate.context.spi.AbstractCurrentSessionContext
baseSessionBuilder, factory, validateExistingSession
-
Constructor Details
-
JTASessionContext
Constructs a JTASessionContext- Parameters:
factory- The factory this context will service
-
-
Method Details
-
currentSession
Description copied from interface:CurrentSessionContextRetrieve the current session according to the scoping defined by this implementation.- Returns:
- The current session.
- Throws:
HibernateException- Typically indicates an issue locating or creating the current session.
-
buildOrObtainSession
Strictly provided for subclassing purposes; specifically to allow long-session support. This implementation always just opens a new session.- Returns:
- the built or (re)obtained session.
-
isAutoCloseEnabled
protected boolean isAutoCloseEnabled()Mainly for subclass usage. This impl always returns true.- Returns:
- Whether the session should be closed by transaction completion.
-
isAutoFlushEnabled
protected boolean isAutoFlushEnabled()Mainly for subclass usage. This impl always returns true.- Returns:
- Whether the session should be flushed prior transaction completion.
-
getConnectionHandlingMode
Mainly for subclass usage. This impl always returns after_statement.- Returns:
- The connection release mode for any built sessions.
-