The Spring Framework

org.springframework.transaction.support
Interface CallbackPreferringPlatformTransactionManager

All Superinterfaces:
PlatformTransactionManager

public interface CallbackPreferringPlatformTransactionManager
extends PlatformTransactionManager

Extension of the PlatformTransactionManager interface, exposing a method for executing a given callback within a transaction.

Implementors of this interface automatically express a preference for callbacks over programmatic getTransaction, commit and rollback calls. Calling code may check whether a given transaction manager implements this interface to choose to prepare a callback instead of explicit transaction demarcation control.

Since:
2.0
Author:
Juergen Hoeller

Method Summary
 Object execute(TransactionDefinition definition, TransactionCallback callback)
          Execute the action specified by the given callback object within a transaction.
 
Methods inherited from interface org.springframework.transaction.PlatformTransactionManager
commit, getTransaction, rollback
 

Method Detail

execute

Object execute(TransactionDefinition definition,
               TransactionCallback callback)
               throws TransactionException,
                      RuntimeException
Execute the action specified by the given callback object within a transaction.

Allows for returning a result object created within the transaction, that is, a domain object or a collection of domain objects. A RuntimeException thrown by the callback is treated as a fatal exception that enforces a rollback. Such an exception gets propagated to the caller of the template.

Parameters:
definition - the definition for the transaction to wrap the callback in
callback - the callback object that specifies the transactional action
Returns:
a result object returned by the callback, or null if none
Throws:
TransactionException - in case of initialization, rollback, or system errors
RuntimeException - if thrown by the TransactionCallback

The Spring Framework

Copyright © 2002-2007 The Spring Framework.