捕获异常的情况下仍然回滚事务

在 MyBatis-Plus 和 Spring 的事务管理机制中,事务的回滚行为与异常的传播有很大关系。如果你捕获了异常并且没有将它重新抛出,那么事务是不会回滚的。

这是因为 @Transactional 注解默认只在未捕获的异常向上传播到 Spring 的事务管理器时,才会触发回滚。捕获异常后,Spring 不再认为这个操作是失败的,事务将正常提交。

示例

捕获异常且不回滚

如果你捕获了异常并且没有抛出它,事务不会回滚:

java 复制代码
@Transactional
public void someTransactionalMethod() {
    try {
        // 业务逻辑
    } catch (Exception e) {
        // 捕获异常,没有抛出
        // 此时事务不会回滚,除非手动调用 setRollbackOnly
    }
}
捕获后手动回滚

如果你需要在捕获异常的情况下仍然回滚事务,可以通过以下两种方式处理:

  1. 手动设置回滚 :通过 TransactionAspectSupport.currentTransactionStatus().setRollbackOnly() 手动标记当前事务为回滚状态:

    java 复制代码
    @Transactional
    public void someTransactionalMethod() {
        try {
            // 业务逻辑
        } catch (Exception e) {
            // 捕获异常后,手动回滚事务
            TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
        }
    }
  2. 重新抛出异常 :在捕获异常后将其重新抛出,让 @Transactional 注解感知异常,从而自动回滚事务:

    java 复制代码
    @Transactional
    public void someTransactionalMethod() {
        try {
            // 业务逻辑
        } catch (Exception e) {
            // 捕获异常后重新抛出
            throw new RuntimeException(e);
        }
    }
相关推荐
这个DBA有点耶22 分钟前
3步抓出慢SQL,别等半夜被叫醒😴
数据库·代码规范
dfdfadffa27 分钟前
SQL窗口函数如何优化嵌套子查询_提升执行效率
jvm·数据库·python
m0_588758481 小时前
如何查看集群版本_crsctl query crs activeversion当前版本
jvm·数据库·python
摇滚侠1 小时前
Oracle19c 导出 Oracle11g 导入,Oracle19c 导出导入,Oracle11g 导出导入
java·数据库·oracle
zh1570231 小时前
CSS如何让元素出现时带抖动_利用关键帧定义抖动动画
jvm·数据库·python
薛定谔的悦2 小时前
共享数据总线(DPR)设计模式——嵌入式系统的“内存数据库”
jvm·数据库·设计模式
程序猿online2 小时前
本地mysql密码重置
数据库·mysql
四维迁跃2 小时前
如何排查SQL存储过程死锁_分析死锁日志与索引优化
jvm·数据库·python
m0_741173332 小时前
如何检测SQL注入风险_利用模糊测试技术发现漏洞
jvm·数据库·python
2401_846339562 小时前
CSS如何解决Less与CSS兼容性问题_通过配置文件实现平滑过渡与混合开发
jvm·数据库·python