Spring 中事务控制的API介绍

时间:2023-03-09 02:10:41
Spring 中事务控制的API介绍

1、PlatformTransactionManager

Spring所有事务代理类都是基于PlatformTransactionManager接口的实现。

此接口是spring的事务管理器,它里面提供了我们常用的操作事务的方法,如下代码片段:

PlatformTransactionManager包括以下三个操作:

//获得事务信息
TransactionStatus getTransaction(TransactionDefinition definition) //提交事务
void commit(TransactionStatus status)
//回滚事务
void rollback(TransactionStatus status)

我们在开发中都是使用它的实现类,如下:

 //用于Spring JDBC以及Mybatis框架的事务代理
DataSourceTransactionManager
//用于Hibernate框架事务代理
HibernateTransactionManager
//用于Jpa框架的事务代理
JpaTransactionManager
//用于JDO框架的事务代码
JdoTransactionManager
//用于Jta事务代理,一个事务跨多资源必须要使用
JtaTransactionManager

2、TransactionDefinition接口

① TransactionDefinition 源码

 1 public interface TransactionDefinition {
//事务的传播行为
int PROPAGATION_REQUIRED = 0;
int PROPAGATION_SUPPORTS = 1;
int PROPAGATION_MANDATORY = 2;
int PROPAGATION_REQUIRES_NEW = 3;
int PROPAGATION_NOT_SUPPORTED = 4;
int PROPAGATION_NEVER = 5;
int PROPAGATION_NESTED = 6;
//事务的隔离级别
int ISOLATION_DEFAULT = -1;
int ISOLATION_READ_UNCOMMITTED = Connection.TRANSACTION_READ_UNCOMMITTED;
int ISOLATION_READ_COMMITTED = Connection.TRANSACTION_READ_COMMITTED;
int ISOLATION_REPEATABLE_READ = Connection.TRANSACTION_REPEATABLE_READ;
int ISOLATION_SERIALIZABLE = Connection.TRANSACTION_SERIALIZABLE;
int TIMEOUT_DEFAULT = -1;
//获得事务信息
int getPropagationBehavior();
int getIsolationLevel();
int getTimeout();
boolean isReadOnly();
String getName();
}

② 说明

  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:是否读取其他提交增加后的数据,解决幻读问题(在一个事务操作时,例外一个事务不能提交,也不能查询)

脏读,如图所示:Spring 中事务控制的API介绍

不可重复读,如图所示:

Spring 中事务控制的API介绍

幻读,如图所示:

Spring 中事务控制的API介绍