Class TransactionTemplate
- All Implemented Interfaces:
- Serializable,- InitializingBean,- TransactionOperations,- TransactionDefinition
The central method is execute(org.springframework.transaction.support.TransactionCallback<T>), supporting transactional code that
 implements the TransactionCallback interface. This template handles
 the transaction lifecycle and possible exceptions such that neither the
 TransactionCallback implementation nor the calling code needs to explicitly
 handle transactions.
 
Typical usage: Allows for writing low-level data access objects that use resources such as JDBC DataSources but are not transaction-aware themselves. Instead, they can implicitly participate in transactions handled by higher-level application services utilizing this class, making calls to the low-level services via an inner-class callback object.
Can be used within a service implementation via direct instantiation with a transaction manager reference, or get prepared in an application context and passed to services as bean reference. Note: The transaction manager should always be configured as bean in the application context: in the first case given to the service directly, in the second case given to the prepared template.
Supports setting the propagation behavior and the isolation level by name, for convenient configuration in context definitions.
- Since:
- 17.03.2003
- Author:
- Juergen Hoeller
- See Also:
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected final org.apache.commons.logging.LogLogger available to subclasses.Fields inherited from class org.springframework.transaction.support.DefaultTransactionDefinitionPREFIX_ISOLATION, PREFIX_PROPAGATION, PREFIX_TIMEOUT, READ_ONLY_MARKERFields inherited from interface org.springframework.transaction.TransactionDefinitionISOLATION_DEFAULT, ISOLATION_READ_COMMITTED, ISOLATION_READ_UNCOMMITTED, ISOLATION_REPEATABLE_READ, ISOLATION_SERIALIZABLE, PROPAGATION_MANDATORY, PROPAGATION_NESTED, PROPAGATION_NEVER, PROPAGATION_NOT_SUPPORTED, PROPAGATION_REQUIRED, PROPAGATION_REQUIRES_NEW, PROPAGATION_SUPPORTS, TIMEOUT_DEFAULT
- 
Constructor SummaryConstructorsConstructorDescriptionConstruct a new TransactionTemplate for bean usage.TransactionTemplate(PlatformTransactionManager transactionManager) Construct a new TransactionTemplate using the given transaction manager.TransactionTemplate(PlatformTransactionManager transactionManager, TransactionDefinition transactionDefinition) Construct a new TransactionTemplate using the given transaction manager, taking its default settings from the given transaction definition.
- 
Method SummaryModifier and TypeMethodDescriptionvoidInvoked by the containingBeanFactoryafter it has set all bean properties and satisfiedBeanFactoryAware,ApplicationContextAwareetc.booleanThis implementation compares thetoString()results.<T> @Nullable Texecute(TransactionCallback<T> action) Execute the action specified by the given callback object within a transaction.Return the transaction management strategy to be used.voidsetTransactionManager(@Nullable PlatformTransactionManager transactionManager) Set the transaction management strategy to be used.Methods inherited from class org.springframework.transaction.support.DefaultTransactionDefinitiongetDefinitionDescription, getIsolationLevel, getName, getPropagationBehavior, getTimeout, hashCode, isReadOnly, setIsolationLevel, setIsolationLevelName, setName, setPropagationBehavior, setPropagationBehaviorName, setReadOnly, setTimeout, toStringMethods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface org.springframework.transaction.support.TransactionOperationsexecuteWithoutResult
- 
Field Details- 
loggerprotected final org.apache.commons.logging.Log loggerLogger available to subclasses.
 
- 
- 
Constructor Details- 
TransactionTemplatepublic TransactionTemplate()Construct a new TransactionTemplate for bean usage.Note: The PlatformTransactionManager needs to be set before any executecalls.
- 
TransactionTemplateConstruct a new TransactionTemplate using the given transaction manager.- Parameters:
- transactionManager- the transaction management strategy to be used
 
- 
TransactionTemplatepublic TransactionTemplate(PlatformTransactionManager transactionManager, TransactionDefinition transactionDefinition) Construct a new TransactionTemplate using the given transaction manager, taking its default settings from the given transaction definition.- Parameters:
- transactionManager- the transaction management strategy to be used
- transactionDefinition- the transaction definition to copy the default settings from. Local properties can still be set to change values.
 
 
- 
- 
Method Details- 
setTransactionManagerSet the transaction management strategy to be used.
- 
getTransactionManagerReturn the transaction management strategy to be used.
- 
afterPropertiesSetpublic void afterPropertiesSet()Description copied from interface:InitializingBeanInvoked by the containingBeanFactoryafter it has set all bean properties and satisfiedBeanFactoryAware,ApplicationContextAwareetc.This method allows the bean instance to perform validation of its overall configuration and final initialization when all bean properties have been set. - Specified by:
- afterPropertiesSetin interface- InitializingBean
 
- 
executeDescription copied from interface:TransactionOperationsExecute 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. - Specified by:
- executein interface- TransactionOperations
- Parameters:
- action- the callback object that specifies the transactional action
- Returns:
- a result object returned by the callback, or nullif none
- Throws:
- TransactionException- in case of initialization, rollback, or system errors
- See Also:
 
- 
equalsDescription copied from class:DefaultTransactionDefinitionThis implementation compares thetoString()results.- Overrides:
- equalsin class- DefaultTransactionDefinition
- See Also:
 
 
-