SpringBoot事务处理总结

Spring boot是默认启动事务的,只需要在类或者方法上添加@Transactional注解即可,但有时候会发现事务不生效,具体原因可以从以下几个方面找寻:

1、首先要看数据库引擎是否支持注解,mysql默认引擎INNODB是支持的但MYISAM是不支持的

2、注解只能被应用到public方法上, 其它方法上不会报错,但不生效;

3、默认情况下只会对运行期异常(java.lang.RuntimeException及其子类)和 Error 进行回滚
在这里插入图片描述4、如果是其它异常,可以显形标记在参数里,下图标红的就是先进行查看用户有指定的异常,如果没有,就默认上一条的异常,参数格式:@Transactional(rollbackFor={Exception.class})
在这里插入图片描述5、是否进行了异常捕获,如果使用了try–catch,事务是肯定不生效,也就是系统没有接收到异常场景;
关于使用异常捕获,还想事务生效,可以有几种策略解决相关难题:

5.1、手动回滚
在这里插入图片描述
5.2、在catch里抛出一个runntimeException
在这里插入图片描述
5.3、将异常写入注解参数里面,也需要抛出来,原理跟方法2一样的,只是重新指定了事务回滚的异常类型
在这里插入图片描述
隔离级别.
在这里插入图片描述Mysql默认采用 REPEATABLE_READ 隔离级别
Oracle默认采用 READ_COMMITTED 隔离级别

在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值