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

在 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);
        }
    }
相关推荐
曹牧18 小时前
Oracle:前缀匹配之REGEXP_LIKE
数据库·oracle
暴躁小师兄数据学院20 小时前
【AI大数据工程师特训笔记】第05讲:关联查询
数据库·sql·oracle
倔强的石头_21 小时前
《Kingbase护城河》——跨平台环境下的数据库联调实战
数据库
lzhdim21 小时前
SQL 入门 17:MySQL 数据类型:从字符串到 JSON 的全面解析
数据库·sql·mysql·json
杨云龙UP21 小时前
Oracle RAC / ODA 生产环境指定 PDB 启动 SOP
linux·运维·数据库·oracle
kingwebo'sZone21 小时前
在Cent上安装Mysql 8.0的遇到的问题和解决办法
数据库·mysql·adb
幽络源小助理21 小时前
最新知识付费系统网站源码 PC+H5双端 附安装教程 – 幽络源源码网
大数据·数据库
小白考证进阶中1 天前
Oracle OCP证书报考&考试全指南
数据库·oracle·oracle ocp·ocp认证·oracle认证·甲骨文认证·oracle ocp题库
Leon-Ning Liu1 天前
【真实经验分享】 ORA-600 [qesmaGetTblSeg1]
数据库·oracle
与数据交流的路上1 天前
MySQL 优化 -- 相关
数据库·mysql