@Transactional注解加不加 rollbackFor = Exception.class 的区别?
(给ImportNew加星标,提高Java技能)
1、首先我在Mysql中准备了一条数据
2、简单粗暴的开始测试了
1、我们的目的是需要把delflag修改为0 简单的准备一下sql
<update id="test">
UPDATE tbl_users set delflag='0' where account='admin'
</update>
2、我们先来测试一下@Transactional
代码如下 大家都知道2/0必会抛出异常
@Override
@Transactional
public Ret test(){
int i = articleMapper.test();
int a = 2/0;
if(i > 0){
ResultUtil.success();
}
return ResultUtil.error();
}
3、执行测试 i=1说明更新成功 别着急咱们继续断点往下面走
java.lang.ArithmeticException: /by zero
ArithmeticException
这个异常类是继承了RuntimeException
的
而@Transactional
默认回滚的的异常就是RuntimeException
RuntimeException
这个类里面一探究竟 我们发现RuntimeException
又是继承Exception
的
而所有的异常类基本都是继承RuntimeException
包括刚才上面的java.lang.ArithmeticException
异常
所以只要是RuntimeException
和RuntimeException
下面的子类抛出的异常 @Transactional
都可以回滚的
1、下面我们在试试@Transactional
不能过滚的异常 代码如下
我们直接先用try catch
来捕获异常 然后在catch里面自定义抛出Exception
异常
@Override
@Transactional
public Ret test() throws Exception {
int i = articleMapper.test();
try {
int a = 2 / 0;
} catch (Exception e) {
throw new Exception();
}
if (i > 0) {
ResultUtil.success();
}
return ResultUtil.error();
}
2、ok直接 抛出的异常是我们指定的java.lang.Exception
异常 我们去看看数据库
@Transactional
并不能回滚Exception异常
总结一下
@Transactional
只能回滚RuntimeException
和RuntimeException
下面的子类抛出的异常 不能回滚Exception
异常
如果需要支持回滚Exception
异常请用@Transactional(rollbackFor = Exception.class)
这里如果是增删改的时候我建议大家都使用@Transactional(rollbackFor = Exception.class)
补充一下@Transactional(rollbackFor = Exception.class)
一些失效的场景:@Transactional 注解失效的3种原因及解决办法
作者:EvenBoy
来源:https://blog.csdn.net/weixin_42169734/article/details/117122084
- EOF -
公司新来一个同事,把 @Transactional 事务注解运用得炉火纯青。。
看了我的MyBatis-Plus用法,同事也开始悄悄模仿了...
看完本文有收获?请转发分享给更多人
关注「ImportNew」,提升Java技能
点赞和在看就是最大的支持❤️