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

在 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);
        }
    }
相关推荐
·云扬·4 分钟前
MySQL分区实战指南:从原理到落地的完整攻略
数据库·mysql
雨墨✘7 分钟前
PHP怎么执行Shell命令_exec与shell_exec区别说明【说明】
jvm·数据库·python
Trouvaille ~13 分钟前
【MySQL篇】复合查询:多表数据的整合
数据库·sql·mysql·面试·复合查询·基础入门·多表连接
Project_Observer15 分钟前
列表视图中的筛选列
大数据·数据库·深度学习·机器学习·深度优先
bukeyiwanshui23 分钟前
20260414 正则表达式及shell三剑客
数据库·mysql·正则表达式
cyber_两只龙宝24 分钟前
【Oracle】Oracle之SQL中的单行函数
linux·运维·数据库·sql·云原生·oracle
2201_7568473328 分钟前
mysql字段长度不够用了怎么办_使用alter table扩大varchar长度
jvm·数据库·python
aq553560036 分钟前
Laravel4.x革命性升级:现代PHP开发新纪元
数据库·oracle
Trouvaille ~1 小时前
【MySQL篇】内外连接:多表关联的完整指南
android·数据库·mysql·面试·后端开发·dql·内外连接
KKKlucifer1 小时前
三权分立 + AI 审计:解析国内堡垒机的合规与智能双引擎
大数据·数据库·人工智能