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

在 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);
        }
    }
相关推荐
国服第二切图仔26 分钟前
鸿蒙应用开发之实现键值型数据库跨设备数据同步
数据库·wpf·harmonyos
盒马coding1 小时前
PostgreSQL18新功能COPY命令变得更加用户友好
数据库·postgresql
️️(^~^)2 小时前
触发器,存储过程
数据库
罗光记2 小时前
Quantinuum 发布新型量子计算机“Helios“
数据库·经验分享·其他·百度·twitter
友友马2 小时前
『 数据库 』MySQL索引深度解析:从数据结构到B+树的完整指南
数据库·mysql
SelectDB2 小时前
替换 ClickHouse,查询并发提升 7 倍!高途教育基于阿里云 SelectDB 构建秒级实时报表
数据库·apache
JamSlade3 小时前
优化用户体验的小点:乐观更新链路 双数据库查询
数据库·ux
一 乐3 小时前
个人博客|博客app|基于Springboot+微信小程序的个人博客app系统设计与实现(源码+数据库+文档)
java·前端·数据库·spring boot·后端·小程序·论文
小二·3 小时前
用 eBPF 实现 MySQL 慢查询实时追踪(终极实战版):零侵入、毫秒级、全上下文捕获
数据库·mysql·adb
云飞云共享云桌面3 小时前
三维设计办公资源如何共享集中和安全管控?
运维·服务器·数据库·安全·自动化·制造