Spring 中事务控制的API介绍
1、PlatformTransactionManager
Spring所有事务代理类都是基于PlatformTransactionManager接口的实现。
此接口是spring的事务管理器,它里面提供了我们常用的操作事务的方法,如下代码片段:
PlatformTransactionManager包括以下三个操作:
//获得事务信息
TransactionStatus getTransaction(TransactionDefinition definition)
//提交事务
void commit(TransactionStatus status)
//回滚事务
void rollback(TransactionStatus status)
我们在开发中都是使用它的实现类,如下:
1 //用于Spring JDBC以及Mybatis框架的事务代理
2 DataSourceTransactionManager
3 //用于Hibernate框架事务代理
4 HibernateTransactionManager
5 //用于Jpa框架的事务代理
6 JpaTransactionManager
7 //用于JDO框架的事务代码
8 JdoTransactionManager
9 //用于Jta事务代理,一个事务跨多资源必须要使用
10 JtaTransactionManager
2、TransactionDefinition接口
① TransactionDefinition 源码
1 public interface TransactionDefinition { 2 //事务的传播行为 3 int PROPAGATION_REQUIRED = 0; 4 int PROPAGATION_SUPPORTS = 1; 5 int PROPAGATION_MANDATORY = 2; 6 int PROPAGATION_REQUIRES_NEW = 3; 7 int PROPAGATION_NOT_SUPPORTED = 4; 8 int PROPAGATION_NEVER = 5; 9 int PROPAGATION_NESTED = 6; 10 //事务的隔离级别 11 int ISOLATION_DEFAULT = -1; 12 int ISOLATION_READ_UNCOMMITTED = Connection.TRANSACTION_READ_UNCOMMITTED; 13 int ISOLATION_READ_COMMITTED = Connection.TRANSACTION_READ_COMMITTED; 14 int ISOLATION_REPEATABLE_READ = Connection.TRANSACTION_REPEATABLE_READ; 15 int ISOLATION_SERIALIZABLE = Connection.TRANSACTION_SERIALIZABLE; 16 int TIMEOUT_DEFAULT = -1; 17 //获得事务信息 18 int getPropagationBehavior(); 19 int getIsolationLevel(); 20 int getTimeout(); 21 boolean isReadOnly(); 22 String getName(); 23 }
② 说明
TransactionDefinition是事务定义接口,该接口注意定义了:事务的传播行为,事务的隔离级别,获得事务信息的方法。所以在配置事务的传播行为,事务的隔离级别已经需要获得事务信息时,可以通过查阅该类的代码获得相关信息。
③ 事务的传播行为
问题:事务的传播行为是什么?
答:我们的业务程序,是通过方法调用另一个方法的。所谓的Spring事务的传播行为,就是指将上一个方法定义的事务处理,是否传递到下一个方法的几种情况。
问题:为什么会出现事务的传播行为?
答:原因是因为在处理业务的时候,一条线程有可能出现多个事务处理对象!!事务的传播行为就是用于描述,出现多个事务对象的时候,它们的关系是怎样的!!
REQUIRED:如果当前没有事务,就新建一个事务,如果已经存在一个事务中,加入到这个事务中。一般的选择(默认值)99%
SUPPORTS:支持当前事务,如果当前没有事务,就以非事务方式执行(没有事务)
MANDATORY:使用当前的事务,如果当前没有事务,就抛出异常
REQUERS_NEW:新建事务,如果当前在事务中,把当前事务挂起。
//查询的时候配置
NOT_SUPPORTED:以非事务方式执行操作,如果当前存在事务,就把当前事务挂起
//查询的时候配置
NEVER:以非事务方式运行,如果当前存在事务,抛出异常
NESTED:如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行REQUIRED类似的操作。
就是:出现多个事务(操作)时,通过事务的传播行为来设置事务与事务之间的存在关系。
④ 事务隔离级别
所谓的事务隔离级别就是,同一个数据库出现多个不同的线程操作(事务)。每个事务之间的关系就是事务隔离级别。
MySQL查询数据库当前的隔离级别的语句为:select @@tx_isolation;
ISOLATION_DEFAULT:默认隔离级别,由数据库本身决定以下四种中的某一种。
根据现实情况,事务隔离级别有四个。
根据四个隔离级别,可能会出现,脏读,不可重复读,幻读
ISOLATION_READ_UNCOMMITTED:可以读取另一个事务未提交的数据
(一个事务操作时,另一个事务可以查询,也可以提交,还可以读取别的事务没有提交的数据)
ISOLATION_READ_COMMITTED :只能读已提交的数据,(解决脏读问题,ORACLE默认)
(一个事务操作(增删改)时,另一个事务可以查询,也可以提交,但是不能读取别的是没有提交的数据)
ISOLATION_REPEATABLE_READ:是否读取其他事务提交修改后的数据,解决不可以重复读问题(MySQL默认)(在一个事务操作时,另外一个事务不能提交,但是可以查询,适合!!!)
ISOLATION_SERIALIZABLE:是否读取其他提交增加后的数据,解决幻读问题(在一个事务操作时,例外一个事务不能提交,也不能查询)
脏读,如图所示:
不可重复读,如图所示:
幻读,如图所示: