@Transactional事物失效的场景总结
作者:互联网
一、底层数据库引擎不支持事物
MySQL中,MyISAM引擎不支持事物,InnoDB 支持事物
二、非public修饰的方法
@Transactional注解只有在public修饰的方法下使用,才会失效
三、@Transactional属性配置错误
-
rollbackFor属性错误
@Transactional回滚事物时,默认的异常是RuntimeException,若要在抛其他异常时也使事物生效,需要指定异常,如:
@Transactional(rollbackFor = Exception.class)
-
propagation属性错误
@Transactional默认的事务传播机制是:REQUIRED,若指定成了NOT_SUPPORTED、NEVER事务传播机制,则事物不生效,如:@Transactional(propagation = Propagation.NOT_SUPPORTED)
四、 异常被吃了
异常被吃了,没抛出异常,如:
@Transactional(rollbackFor = Exception.class)
public void A(){
try{
......
}catch(Exception e){
// 未抛异常
}
}
五、未被Spring管理
// 注释调@Component,该类没被Spring管理,事物也是不生效的
public class Demo {
@Transactional(rollbackFor = Exception.class)
public void A() {
......
}
}
六、发生了自身调用
在Demo类中,A方法调用了B方法,导致B方法的事物不生效,如:
@Service
public class Demo {
public void A() {
......
B();
}
@Transactional(rollbackFor = Exception.class)
public void B() {
......
}
}
解决办法
法一: 将A和B方法拆分到不同的类中
法二:注入自己,如:
@Service
public class Demo {
@Resource
private ApplicationContext applicationContext;
public void A() {
// 注入自己
Demo demoMyself = (Demo)applicationContext.getBean("demo");
......
demoMyself.B();
}
@Transactional(rollbackFor = Exception.class)
public void B() {
......
}
}
标签:Exception,场景,Transactional,rollbackFor,class,void,失效,public 来源: https://blog.csdn.net/qq_44837912/article/details/118874285