问题:开发中遇到事物方法A 在事物方法B中调用 A抛出异常被B捕获 A中执行的数据未被回滚
疑惑:当AB方法在一个service中 A不能被回滚,当AB位于不同service中A能被回滚
原因及背景分析:
spring事物管理通过AOP实现,AOP基于代理对象,存在service原对象 及 service代理对象
当AB方法在同一service中,当AB都加Transactional ,AOP给代理对象加事物管理,调用B方法时B调用了原对象的A方法,导致AB方法实际在一个事物管理中,事物的执行依赖于外层事物,被捕获的异常不会影响到A方法的执行,外层事物(实际有效事物)完成了他的工作,保证方法执行完成。
当AB方法在不同service,当AB方法都加transactional,AOP给两个service即两个代理对象加了事物管理,调用B方法时,B调用Aservice的A方法是不同的两个事物,A方法的错误受自己的事物控制,所以能回滚
当AB在同一个service中,即使AB都配置@Transactional(propagation = Propagation.REQUIRES_NEW),也不能使两个方法位于不同事物控制,如果需要让AB分别受不同事物控制,可以简单的把AB方法写在不同的service中或者配置spring手动事物管理 手动控制事物。
Ps:private方法不受Transactional注解控制
PPS:以上为测试和推测所写,可以参考,具体需看源码