目录
@Transactional
public String insertOrder(OrderEntity orderEntity,UserEntity userEntity){
int insertOrder = orderMappler.insert(orderEntity);
String result = memberMange.insertMember(userEntity) > 0 ? "success" : "fail";
int j = 1/0;
return result;
}
首先insertOrder()方法是A方法(外层方法),而insertMember()是B方法(内层方法),属于A调用B。
因为有了@Transactional注解,所以第一句代码insert开启事务(外层事务),第二句代码调用了方法,insertMember()方法也有@Transactional注解,所以开启了内层事务。当第三句代码报错时,这时候我们要问自己一个问题:
(1)当外层方法里有代码报错时,内层方法是否也进行回滚。
(2)内层方法里代码报错时,外层事务是否也进行回滚。
注意:下面举的例子,直接访问B,也相当于A(无事务)调用B。
定义:如果外层方法存在一个事务,则加入外层事务,如果外层没有事务则自己开启一个新的事务。
如果B方法的事务是required:
当A调用B方法时,则B方法会加入A方法的事务。当A方法里有代码报错时,B方法也会回滚。
当直接访问B方法时,则B方法会新创建一个事务。
也就是说,A调用B也好,直接访问B也好,都会执行事务,出错就会回滚。
定义:如果外层方法存在一个事务,则加入外层事务。如果外层没有事务,则以非事务的形式执行。
如果B方法的事务是required:
当A调用B方法时,则B方法会加入A方法的事务。当A方法里有代码报错时,B方法也会回滚。
当直接访问B方法时,则B方法会以非事务的形式执行,B出错不会回滚。
定义:如果外层方法存在一个事务,则加入外层事务。如果外层方法没有一个活动的事务,则抛出异常。
如果B方法的事务是required:
当A调用B方法时,则B方法会加入A方法的事务。当A方法里有代码报错时,B方法也会回滚。
当直接访问B方法时,则B方法会直接抛出异常,因为它必须存活在事务中。
定义:总是开启一个新的事务,如果一个事务已经存在,则将这个存在的事务挂起。其实就是A方法有事务,B方法事务是requires_new,这时A调用B,B会将A的事务挂起(不用你的),我自己创建一个新的事务 ,也就是说 现在A是没有事务的,只有B有,所以就会导致B方法里代码有异常,只会回滚B,并不会回滚A。
定义:总是以非事务的形式运行,并挂起任何存在的事务。
不管是A调用B,还是直接访问B,都是无事务的,出问题不会回滚。
定义:总是以非事务的形式运行,如果外层方法有事务,则抛出异常。
定义:如果一个活动的事务存在,则运行在一个嵌套的事务中。 如果没有活动事务, 则按TransactionDefinition.PROPAGATION_REQUIRED 属性执行。