Package io.micronaut.transaction.jdbc
Class JdbcTransactionObjectSupport
java.lang.Object
io.micronaut.transaction.jdbc.JdbcTransactionObjectSupport
- All Implemented Interfaces:
- SavepointManager,- SmartTransactionObject,- Flushable
@Internal
public abstract class JdbcTransactionObjectSupport
extends Object
implements SavepointManager, SmartTransactionObject
Convenient base class for JDBC-aware transaction objects. Can contain a
 
ConnectionHolder with a JDBC Connection, and implements the
 SavepointManager interface based on that ConnectionHolder.
 Allows for programmatic management of JDBC Savepoints.
 DefaultTransactionStatus
 automatically delegates to this, as it autodetects transaction objects which
 implement the SavepointManager interface.
- Since:
- 1.1
- Author:
- Juergen Hoeller, graemerocher
- See Also:
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionThis implementation creates a JDBC 3.0 Savepoint and returns it.voidflush()Flush the underlying sessions to the datastore, if applicable: for example, all affected Hibernate/JPA sessions.Retrieves the connection holder.protected ConnectionHolderbooleanbooleanvoidreleaseSavepoint(Object savepoint) This implementation releases the given JDBC 3.0 Savepoint.voidrollbackToSavepoint(Object savepoint) This implementation rolls back to the given JDBC 3.0 Savepoint.voidsetConnectionHolder(ConnectionHolder connectionHolder) Sets the connection holder.voidsetPreviousIsolationLevel(TransactionDefinition.Isolation previousIsolationLevel) Sets the previous isolation level.voidsetSavepointAllowed(boolean savepointAllowed) Sets whether save points are allowed.Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface io.micronaut.transaction.support.SmartTransactionObjectisRollbackOnly
- 
Constructor Details- 
JdbcTransactionObjectSupportpublic JdbcTransactionObjectSupport()
 
- 
- 
Method Details- 
setConnectionHolderSets the connection holder.- Parameters:
- connectionHolder- The connection holder
 
- 
getConnectionHolderRetrieves the connection holder.- Returns:
- The connection holder
 
- 
hasConnectionHolderpublic boolean hasConnectionHolder()- Returns:
- Whether a connection holder is present
 
- 
setPreviousIsolationLevelpublic void setPreviousIsolationLevel(@Nullable TransactionDefinition.Isolation previousIsolationLevel) Sets the previous isolation level.- Parameters:
- previousIsolationLevel- The isolation level
 
- 
getPreviousIsolationLevel- Returns:
- The previous isolation level
 
- 
setSavepointAllowedpublic void setSavepointAllowed(boolean savepointAllowed) Sets whether save points are allowed.- Parameters:
- savepointAllowed- True if they are allowed
 
- 
isSavepointAllowedpublic boolean isSavepointAllowed()- Returns:
- Whether the save point is allowed
 
- 
flushpublic void flush()Description copied from interface:SmartTransactionObjectFlush the underlying sessions to the datastore, if applicable: for example, all affected Hibernate/JPA sessions.- Specified by:
- flushin interface- Flushable
- Specified by:
- flushin interface- SmartTransactionObject
 
- 
createSavepointThis implementation creates a JDBC 3.0 Savepoint and returns it.- Specified by:
- createSavepointin interface- SavepointManager
- Returns:
- a savepoint object, to be passed into
 SavepointManager.rollbackToSavepoint(java.lang.Object)orSavepointManager.releaseSavepoint(java.lang.Object)
- Throws:
- NestedTransactionNotSupportedException- if the underlying transaction does not support savepoints
- TransactionException- if the savepoint could not be created, for example because the transaction is not in an appropriate state
- See Also:
 
- 
rollbackToSavepointThis implementation rolls back to the given JDBC 3.0 Savepoint.- Specified by:
- rollbackToSavepointin interface- SavepointManager
- Parameters:
- savepoint- the savepoint to roll back to
- Throws:
- NestedTransactionNotSupportedException- if the underlying transaction does not support savepoints
- TransactionException- if the rollback failed
- See Also:
 
- 
releaseSavepointThis implementation releases the given JDBC 3.0 Savepoint.- Specified by:
- releaseSavepointin interface- SavepointManager
- Parameters:
- savepoint- the savepoint to release
- Throws:
- NestedTransactionNotSupportedException- if the underlying transaction does not support savepoints
- TransactionException- if the release failed
- See Also:
 
- 
getConnectionHolderForSavepoint- Returns:
- The connection holder for the save point
- Throws:
- TransactionException- If an error occurs retrieving the connection holder
 
 
-