Spring事务的传播行为特性详解


1 传播行为

当一个事务方法被另一个事务方法调用时,必须指定对应的事务传播行为,或者是方法继续执行在现有的事务方法中,或者是开启一个新的事务

2 Spring定义的事务传播行为

Spring源码中,对于事务的传播行为定义是在TransactionDefinition类中,该类定义了事务的一些基本属性,包含事务的传播行为,隔离级别,事务的超时设置,事务是否只读,以及对应的事务名称。

我们重点关注一下事务的传播行为,事务的隔离级别可以参考我的另一篇文章:事务的隔离级别?幻读和不可重复的区别

2.1 PROPAGATION_REQUIRED

Spring事务的传播行为特性详解
该事务的传播行为是Spring默认的事务的传播行为,
表示当前方法必须运行在事务中,如果当前事务存在,方法会在该事务中执行,否则,会启动一个新的事务执行

2.2 PROPAGATION_SUPPORTS

Spring事务的传播行为特性详解
表示当前方法不需要事务执行,但是,如果当前事务存在,加入到当前事务执行

2.3 PROPAGATION_MANDATORY

Spring事务的传播行为特性详解
表示该方法必须以事务的形式运行,如果当前事务不存在,抛出异常

2.4 PROPAGATION_REQUIRES_NEW

Spring事务的传播行为特性详解
表示当前方法总是以一个新的事务形式进行执行,如果当前存在事务,当前事务被挂起,新建事务执行,该事务的传播行为会新建一个事务,并且内部的事务状态不会受到外部已经存在事务的影响,因此,使用PROPAGATION_REQUIRES_NEW时,内层的事务和外层的事务就像两个完全独立的事务状态,一旦内层事务进行了提交后,外层事务不能对其进行回滚。两个事务互不影响。两个事务不是一个真正的嵌套事务

2.5 PROPAGATION_NOT_SUPPORTED

Spring事务的传播行为特性详解
表示该方法不是运行在事务层面,如果当前方法存在事务,事务挂起,执行方法

2.6 PROPAGATION_NEVER

Spring事务的传播行为特性详解
表示当前方法不应该运行在事务上下文中,如果当前存在一个事务运行,抛出异常

2.7 PROPAGATION_NESTED

Spring事务的传播行为特性详解
如果当前事务存在,则以一种嵌套事务形式执行,它是已经存在事务的一个真正的子事务,外层事务的回滚可以引起内层事务的回滚,而内层事务的异常并不会导致外层事务的回滚,如果外部事务 commit, 嵌套事务也会被 commit,