为什么要有传播机制,为了避免产生脏数据。
默认是required。
编辑
编辑
1、以 Supports举例:
当前没有事务
编辑
如果是supports的话,当前没有事务的话,就以非事务方式执行。什么是当前事务?比如test2方法是被test调用的,如果test开启了事务,那么就说test2存在当前事务。如果test没开启事务,就说没当前事务。这里test2没当前事务
编辑
编辑
编辑
这里的情况test2不会回滚,test3也不会回滚
编辑
为什么呢?
因为异常是在test抛出的,test没有开启事务,test3事务机制是默认的required。这种类型是如果当前没有事务,
则新建一个事务。所在事务只在test3方法范围内,test3执行完就提交了,在test里的int i=1/0抛出的异常不会让test3回滚。如果是在test3里面报错的话test3才会回滚。
2、required_new:
用在如果当前方法执行没报错的话就提交,执行报错就回滚。而不想受外部事务影响。
比如,test2开启required_new,test也开启事务,但test报错回滚了,此时test2不会回滚。因为此时test2没报错,它
不想受test报错影响,required_new就是这种场景用。
编辑
编辑
3、通过一个没开启事务的中间对象调用开启事务的test2,只要test是开启事务的,test2的事务也是有效的,相当于跟中间对象有无开启事务无关
编辑
编辑
编辑
4、存在当前事务时,test2即使没加事务注解,也在当前事务中。test2也会回滚
编辑
编辑
5 类中调用自身方法事务注解不生效:
编辑
编辑
这里 int i=1/0报错时,插入的Atlas不会回滚。因为DiseaseServiceImpl自调用,this不是代理对象,所以test2的注解
不生效。
但AtlasServiceImpl的test2的事务注解是生效的。只是异常是在外部发生的,所以Atlas没有回滚。
如果异常在AtlasServiceImpl的test2里发生,Atlas会回滚。