写这篇文章的初衷呢就是最近遇到了一个spring事务的大坑。其实是自己掌握的事务这块知识点儿太薄弱啦。
项目环境 sprinigboot
下面开始问题描述,发生的过程有点长,想直接看方案的直接跳过哦~
项目的业务是工作流审批接口,在接口实现类中A方法去调用B方法。A方法大致就是做了一个区分是一个流程审批还是批量审批(批量就循环调用),去调用审批方法B方法。然后B审批方法上面打了事务。
然后批量审批时发现,由于第一条审批数据的结果影响了第二条的审批过程,报错,正常是要回滚第二条数据的审批操作。然而惊讶的发现 没有回滚。。。。
下面开始一步步分析解决问题:
首先我们来看下spring事务的传播机制及原因分析;
PROPAGATION_REQUIRED – 支持当前事务,如果当前没有事务,就新建一个事务。这是最常见的选择。
PROPAGATION_SUPPORTS – 支持当前事务,如果当前没有事务,就以非事务方式执行。
PROPAGATION_MANDATORY – 支持当前事务,如果当前没有事务,就抛出异常。
PROPAGATION_REQUIRES_NEW – 新建事务,如果当前存在事务,把当前事务挂起。
PROPAGATION_NOT_SUPPORTED – 以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。
PROPAGATION_NEVER – 以非事务方式执行,如果当前存在事务,则抛出异常。
PROPAGATION_NESTED – 如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则进行与PROPAGATION_REQUIRED类似的操作。
spring默认的是PROPAGATION_REQUIRED机制,如果方法A标注了注解@Transactional