事务管理的核心接口
在Spring的所有JAR包中,包含一个名为spring-tx-4.3.6.RELEASE的JAR包,该包就是Spring提供的用于事务管理的依赖包。在该JAR包的org.springframework.transaction包中,我们可以找到3个接口文件PlatformTransactionManager、TransactionDefinition和TransactionStatus,如图1所示。
图1 事务管理核心接口
在图1中,方框标注的3个接口文件就是Spring事务管理所涉及的3个核心接口,接下来对这3个接口的作用分别进行讲解。
1、 PlatformTransactionManager
PlatformTransactionManager接口是Spring提供的平台事务管理器,主要用于管理事务。该接口中提供了三个事务操作的方法,具体如下:
● TransactionStatus getTransaction(TransactionDefinition definition ):用于获取事务状态信息;
● void commit(TransactionStatus status):用于提交事务;
● void rollback(TransactionStatus status):用于回滚事务。
在上面的3个方法中,getTransaction(TransactionDefinition definition )方法会根据TransactionDefinition参数返回一个TransactionStatus对象,TransactionStatus对象就表示一个事务,它被关联在当前执行的线程上。
PlatformTransactionManager接口只是代表事务管理的接口,它并不知道底层是如何管理事务的,它只需要事务管理提供上面的3个方法,但具体如何管理事务则由它的实现类来完成。
PlatformTransactionManager接口有许多不同的实现类,常见的几个实现类如下:
● org.springframework.jdbc.datasource.DataSourceTransactionManager:用于配置JDBC数据源的事务管理器;
● org.springframework.orm.hibernate4.HibernateTransactionManager:用于配置Hibernate的事务管理器;
● org.springframework.transaction.jta.JtaTransactionManager:用于配置全局事务管理器。
当底层采用不同的持久层技术时,系统只需使用不同的PlatformTransactionManager实现类即可。
2、 TransactionDefinition
TransactionDefinition接口是事务定义(描述)的对象,该对象中定义了事务规则,并提供了获取事务相关信息的方法,具体如下:
● String getName():获取事务对象名称。
● int getIsolationLevel():获取事务的隔离级别。
● int getPropagationBehavior():获取事务的传播行为。
● int getTimeout():获取事务的超时时间。
● boolean isReadOnly():获取事务是否只读。
上述方法中,事务的传播行为是指在同一个方法中,不同操作前后所使用的事务。传播行为有很多种,具体如表1所示。
表1 传播行为的种类
属性名称 | 值 | 描述 |
---|---|---|
PROPAGATION_REQUIRED | REQUIRED | 表示当前方法必须运行在一个事务环境当中,如果当前方法已处于事务环境中,则可以直接使用该方法;否则会开启一个新事务后执行该方法。 |
PROPAGATION_SUPPORTS | SUPPORTS | 如果当前方法处于事务环境中,则使用当前事务,否则不使用事务。 |
PROPAGATION_MANDATORY | MANDATORY | 表示调用该方法的线程必须处于当前事务环境中,否则将抛异常。 |
PROPAGATION_REQUIRES_NEW | REQUIRES_NEW | 要求方法在新的事务环境中执行。如果当前方法已在事务环境中,则先暂停当前事务,在启动新的事务后执行该方法;如果当前方法不在事务环境中,则会启动一个新的事务后执行方法。 |
PROPAGATION_NOT_SUPPORTED | NOT_SUPPORTED | 不支持当前事务,总是以非事务状态执行。如果调用该方法的线程处于事务环境中,则先暂停当前事务,然后执行该方法。 |
PROPAGATION_NEVER | NEVER | 不支持当前事务。如果调用该方法的线程处于事务环境中,将抛异常。 |
PROPAGATION_NESTED | NESTED | 即使当前执行的方法处于事务环境中,依然会启动一个新的事务,并且方法在嵌套的事务里执行;即使当前执行的方法不在事务环境中,也会启动一个新事务,然后执行该方法。 |
在事务管理过程中,传播行为可以控制是否需要创建事务以及如何创建事务,通常情况下,数据的查询不会影响原数据的改变,所以不需要进行事务管理,而对于数据的插入、更新和删除操作,必须进行事务管理。如果没有指定事务的传播行为,Spring默认传播行为是REQUIRED。
3、 TransactionStatus
TransactionStatus接口是事务的状态,它描述了某一时间点上事务的状态信息。该接口中包含6个方法,具体如下:
● void flush():刷新事务;
● boolean hasSavepoint():获取是否存在保存点;
● boolean isCompleted():获取事务是否完成;
● boolean isNewTransaction():获取是否是新事务;
● boolean isRollbackOnly():获取是否回滚;
● void setRollbackOnly():设置事务回滚