Spring: try-catch 是否还会回滚
问题出现:
try-catch 语句 依旧会抛出如下错误
org.springframework.transaction.TransactionSystemException: Could not commit JPA transaction; nested exception is javax.persistence.RollbackException: Transaction marked as rollbackOnlyat org.springframework.orm.jpa.JpaTransactionManager.doCommit(JpaTransactionManager.java:526)at org.springframework.transaction.support.AbstractPlatformTransactionManager.processCommit(AbstractPlatformTransactionManager.java:761)at org.springframework.transaction.support.AbstractPlatformTransactionManager.commit(AbstractPlatformTransactionManager.java:730)at org.springframework.transaction.interceptor.TransactionAspectSupport.commitTransactionAfterReturning(TransactionAspectSupport.java:518)at org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:292)at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:96)
问题解决:
try-catch 为什么还会事务回滚
在编程中,使用 try-catch 语句块确实可以帮助你捕获和处理异常,但这并不直接影响数据库事务的提交或回滚。事务的提交或回滚通常是由事务管理器根据事务的边界和事务属性(如隔离级别、传播行为等)来控制的,而不是直接由 try-catch 语句块控制的。
然而,有几个原因可能导致在使用 try-catch 时事务仍然回滚:
-
未捕获的异常:如果事务中的代码抛出了未被
try-catch捕获的异常,那么这个异常将传播到事务的边界,导致事务管理器触发回滚操作。 -
运行时异常:在 Spring 等框架中,默认情况下,运行时异常(
RuntimeException及其子类)会导致事务回滚。即使你在try-catch中捕获了这些异常,如果没有显式地调用事务的提交方法(在大多数场景下,这是不必要的,因为框架会为你管理事务),事务管理器仍然会根据异常的类型和配置来决定是否回滚事务。 -
事务传播行为:如果你在一个已经存在的事务中开始了一个新的事务(例如,使用了 Spring 的
@Transactional注解,并且事务的传播行为是REQUIRED或其他允许嵌套事务的行为),那么内部事务的异常可能会影响到外部事务的状态,导致外部事务也回滚。这取决于具体的事务管理器和配置。 -
事务回滚的显式请求:在某些情况下,你的代码可能显式地请求了事务回滚,即使异常被捕获了。例如,在 Spring 中,你可以通过编程方式调用
TransactionStatus.setRollbackOnly()来标记事务需要回滚。 -
框架或容器的行为:使用的框架或容器(如 Spring、EJB 等)可能有自己的事务管理策略,这些策略可能会根据捕获的异常类型、事务的属性或其他因素来决定是否回滚事务。
-
数据库约束:即使你的代码中没有异常,数据库级别的约束(如主键冲突、外键约束等)也可能导致 SQL 语句执行失败,从而触发事务回滚。
因此,当你看到即使使用了 try-catch 事务仍然回滚时,你应该检查以下几点:
- 是否有未捕获的异常。
- 是否捕获了运行时异常但期望事务继续。
- 事务的传播行为和嵌套事务的处理方式。
- 是否有显式地请求事务回滚的代码。
- 数据库约束是否可能导致事务失败。
此外,了解你使用的框架或容器的事务管理策略和配置也是非常重要的。
捕获了运行时异常但期望事务继续
在大多数现代Java框架(如Spring)中,运行时异常(RuntimeException 及其子类)默认会导致事务回滚。这是因为运行时异常通常表示程序中的错误,这些错误可能破坏了数据的完整性或一致性,因此框架选择自动回滚事务以避免潜在的问题。
然而,如果你捕获了运行时异常但仍然希望事务继续(即不触发回滚),你需要采取一些额外的步骤来确保这一点。但是,请注意,这种做法通常是不推荐的,因为它可能隐藏了潜在的问题并导致数据不一致。
在Spring框架中,你可以通过以下几种方式来处理这个问题:
-
使用
@Transactional(noRollbackFor = ...)或@Transactional(noRollbackForClassName = ...)你可以在服务层的方法上使用
@Transactional注解,并通过noRollbackFor或noRollbackForClassName属性来指定哪些异常不应该导致事务回滚。但是,请注意这些属性只接受编译时异常(即那些继承自Exception但不继承自RuntimeException的异常)。对于运行时异常,你需要使用@Transactional(rollbackFor = Exception.class, noRollbackFor = YourSpecificRuntimeException.class)这样的组合,但实际上由于Exception.class已经包括了所有的异常,所以只需要noRollbackFor就足够了。但更常见的做法是将rollbackFor留空,仅使用noRollbackFor。然而,由于
noRollbackFor不直接支持运行时异常,你需要显式地列出不希望回滚的运行时异常类型。
@Transactional(noRollbackFor = YourSpecificRuntimeException.class)
public void yourServiceMethod() { try { // 可能会抛出 YourSpecificRuntimeException 的代码 } catch (YourSpecificRuntimeException e) { // 处理异常,但希望事务继续 // 注意:这里不会阻止事务回滚,因为@Transactional的noRollbackFor属性需要精确匹配 }
}
-
但是,由于Spring的
@Transactional注解在方法边界上处理事务,并且不直接检查方法体内部的异常处理逻辑,因此上述noRollbackFor的使用实际上是在说:“如果这个方法抛出了YourSpecificRuntimeException,请不要回滚事务。” 它并不依赖于你是否在方法内部捕获了这个异常。
-
编程式事务管理
如果你需要更细粒度的控制,可以考虑使用编程式事务管理。这允许你在代码中显式地开始、提交或回滚事务。但是,这种方法更加复杂,并且通常不推荐用于服务层方法,因为它与声明式事务管理相比更加繁琐且容易出错。
-
重新考虑异常处理策略
最后,你可能需要重新考虑你的异常处理策略。通常,如果一个运行时异常表明数据可能已经处于不一致的状态,那么回滚事务是保护数据完整性的正确做法。如果你的业务逻辑允许在发生特定运行时异常时继续执行(尽管这很少见),你可能需要重新设计你的业务逻辑或异常处理逻辑,以确保数据的一致性和完整性不会受到影响。
总的来说,虽然你可以通过@Transactional注解的noRollbackFor属性来防止某些特定的运行时异常导致事务回滚,但通常建议仔细考虑是否真的需要这样做,并确保你的业务逻辑和数据完整性不会因此受到损害。
--end--
相关文章:
Spring: try-catch 是否还会回滚
问题出现: try-catch 语句 依旧会抛出如下错误 org.springframework.transaction.TransactionSystemException: Could not commit JPA transaction; nested exception is javax.persistence.RollbackException: Transaction marked as rollbackOnlyat org.springf…...
spdlog日志库--基础介绍
文章目录 1. 简介1.1. spdlog代码特点1.2. 说明1.3. spdlog架构 2. spdlog的安装2.1. 使用包管理器安装2.2. 使用源码安装2.3. 仅使用头文件 3. 相关概念3.0 常用的头文件3.1. level_enum3.2. sink3.3. logger3.4 格式输出3.5 对齐方式3.6 截断3.7 字符串格式化fmt 4. 特性4.1.…...
【网络】网络编程套接字(二)
网络编程套接字(二) 文章目录 1.单执行流的TCP网络程序1.1服务端创建套接字1.2服务端绑定1.3服务端监听1.4服务端获取链接1.5服务端处理请求1.6客户端创建套接字1.7客户端连接服务器1.8客户端发起请求 2.多进程版的TCP网络程序2.1单执行流的弊端2.2多进…...
1.1、centos stream 9安装Kubernetes v1.30集群 环境说明
最近正在学习kubernetes,买了一套《Kubernetes权威指南 从Docker到Kubernetes实践全接触(第六版)》这本书讲得很好,上下两册,书中k8s的版本是V1.29,目前官网最新版本是v1.30。强烈建议大家买一套看看。 Kubernetes官网地址&#x…...
Redis3
目录 什么是缓存穿透?怎么解决? 什么是缓存雪崩?怎么解决? 如何保证数据库和缓存的数据一致性? 如何保证Redis服务高可用? 哨兵的作用 Redis虚拟槽分区有什么优点? 为什么Redis集群最大槽…...
Oracle数据巡检 - 设计巡检模板
设计巡检模板 明确巡检数据库等信息 包括数据库种类、版本、架构、数量等,例如 Oracle DG和Oracle RAC数据库巡检项肯定会有差异,Oracle 11g和12c版本巡检内容也会有所不同。 明确巡检项 这一块需要结合自身的运维经验,列出详尽的巡检项&…...
优盘未格式化数据恢复实战指南
在数字时代,优盘(USB闪存驱动器)作为便携存储媒介,承载着无数重要的文件与数据。然而,当您插入优盘准备访问资料时,却遭遇了“驱动器未被格式化”的提示,这无疑是一场突如其来的数据危机。本文将…...
【python基础】python基础习题练习(一)
文章目录 一. python语言简介二. python基本语法与常用函数三. python基本数据类型一.选择题二.编程题四. python组合数据类型一.选择题二.简答题三.编程题一. python语言简介 查看python是否安装成功的命令是:python -vPython IDE有:pyCharm、Spyder、Jupter NotebookPython…...
GESP 4级样题 ---> 绝对素数
这题需要判断一个数和它的反转后的数是否都为素数。 可以转成 string 后 reverse 一下。 AC CODE: #include <bits/stdc.h> using namespace std; typedef long long LL; bool isPrime(int x){if(x<2) return false;for(int i2;i*i<x;i){if(x%i0) re…...
大语言模型系列 - Transformer
1. 简介 1.1. 概述 大语言模型Transformer是一种由谷歌公司提出的基于注意力机制的神经网络模型,它在自然语言处理(NLP)领域取得了显著成就,并逐渐被应用于其他领域如语音识别、计算机视觉和强化学习等。 1.2. 学习资源 以下是一些学习大语言模型Transformer的资源地址…...
Java面试之操作系统
1、冯诺依曼模型 运算器、控制器、存储器、输入设备、输出设备 32位和64位CPU最主要区别是一次性能计算多少字节数据,如果计算的数额不超过 32 位数字的情况下,32 位和 64 位 CPU 之间没什么区别的,只有当计算超过 32 位数字的情况下&#…...
springboot船舶维保管理系统--论文源码调试讲解
第二章 相关技术 本次开发船舶维保管理系统使用的是Vue进行程序开发,船舶维保管理系统的数据信息选择MySQL数据库进行存放。 2.1 VUE介绍 Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue…...
【机器学习西瓜书学习笔记——神经网络】
机器学习西瓜书学习笔记【第五章】 第五章 神经网络5.1神经元模型5.2 感知机与多层网络学习感知机学习率成本/损失函数梯度下降 5.3 BP神经网络(误差逆传播)5.4 全局最小与局部极小5.5 其他常见神经网络RBF网络RBF 与 BP 最重要的区别 ART网络 第五章 神…...
安装 electron 报错解决
1. 报错 大概率由镜像问题导致 2. 解决 2.1 打开 npm 配置 npm config edit 2.2 添加配置 registryhttps://registry.npmmirror.comelectron_mirrorhttps://cdn.npmmirror.com/binaries/electron/electron_builder_binaries_mirrorhttps://npmmirror.com/mirrors/electron…...
【Material-UI】Icon Button 组件详解
文章目录 一、基础用法1. 禁用状态 二、大小(Sizes)1. 小尺寸(Small)2. 大尺寸(Large) 三、颜色(Colors)1. 主题颜色2. 自定义颜色 四、高级用法和最佳实践1. 无障碍性(A…...
51单片机-第七节-DS1302实时时钟
一、DS1302介绍: 实时时钟芯片,可对年,月,日,周,时,分,秒计时,是一种集成电路。 二、DS1302原理: 1.寄存器定义: Command:操作模式…...
Java毕业设计 基于SSM和Vue的图书馆座位预约系统小程序
Java毕业设计 基于SSM和Vue的图书馆座位预约系统小程序 这篇博文将介绍一个基于SSM框架和Vue开发的图书馆座位预约系统微信小程序,适合用于Java毕业设计。 功能介绍 用户 登录 注册 首页 图片轮播 关于我们 公告信息 图书馆信息 图书馆详情 预约选座 收藏 …...
【C++11】:lambda表达式function包装器
目录 前言一,可变参数模板1.1 简单认识1.2 STL容器中的empalce系列相关接口 二,lambda表达式2.1 lambda表达式语法2.2 探索lambda底层 三,包装器3.1 function包装器3.2 bind 四,类的新功能4.1 默认成员函数4.2 关键字default4.3 关…...
[io]进程间通信 -有名、无名管道 区别
有名管道和无名管道的区别 无名管道有名管道 使用场景 亲缘关系进程不相关的任意进程特点 1.固定读端fd[0]写端fd[1] 2.文件IO进行操作 3.不支持lseek()操作 4.数据存储在内核空间 1.文件系统中存在管道文件 2.文件IO操作 3.不支持lseek 4.先进先出 5.数…...
pywinauto:Windows桌面应用自动化测试(七)
前言 上一篇文章地址: pywinauto:Windows桌面应用自动化测试(六)-CSDN博客 下一篇文章地址: 暂无 一、实战常用方法 1、通过Desktop快速获取窗口 通过之前章节我们了解到控制应用的方法为Application࿰…...
Docker 离线安装指南
参考文章 1、确认操作系统类型及内核版本 Docker依赖于Linux内核的一些特性,不同版本的Docker对内核版本有不同要求。例如,Docker 17.06及之后的版本通常需要Linux内核3.10及以上版本,Docker17.09及更高版本对应Linux内核4.9.x及更高版本。…...
Mybatis逆向工程,动态创建实体类、条件扩展类、Mapper接口、Mapper.xml映射文件
今天呢,博主的学习进度也是步入了Java Mybatis 框架,目前正在逐步杨帆旗航。 那么接下来就给大家出一期有关 Mybatis 逆向工程的教学,希望能对大家有所帮助,也特别欢迎大家指点不足之处,小生很乐意接受正确的建议&…...
基于服务器使用 apt 安装、配置 Nginx
🧾 一、查看可安装的 Nginx 版本 首先,你可以运行以下命令查看可用版本: apt-cache madison nginx-core输出示例: nginx-core | 1.18.0-6ubuntu14.6 | http://archive.ubuntu.com/ubuntu focal-updates/main amd64 Packages ng…...
Java入门学习详细版(一)
大家好,Java 学习是一个系统学习的过程,核心原则就是“理论 实践 坚持”,并且需循序渐进,不可过于着急,本篇文章推出的这份详细入门学习资料将带大家从零基础开始,逐步掌握 Java 的核心概念和编程技能。 …...
uniapp中使用aixos 报错
问题: 在uniapp中使用aixos,运行后报如下错误: AxiosError: There is no suitable adapter to dispatch the request since : - adapter xhr is not supported by the environment - adapter http is not available in the build 解决方案&…...
【碎碎念】宝可梦 Mesh GO : 基于MESH网络的口袋妖怪 宝可梦GO游戏自组网系统
目录 游戏说明《宝可梦 Mesh GO》 —— 局域宝可梦探索Pokmon GO 类游戏核心理念应用场景Mesh 特性 宝可梦玩法融合设计游戏构想要素1. 地图探索(基于物理空间 广播范围)2. 野生宝可梦生成与广播3. 对战系统4. 道具与通信5. 延伸玩法 安全性设计 技术选…...
Mobile ALOHA全身模仿学习
一、题目 Mobile ALOHA:通过低成本全身远程操作学习双手移动操作 传统模仿学习(Imitation Learning)缺点:聚焦与桌面操作,缺乏通用任务所需的移动性和灵活性 本论文优点:(1)在ALOHA…...
安全突围:重塑内生安全体系:齐向东在2025年BCS大会的演讲
文章目录 前言第一部分:体系力量是突围之钥第一重困境是体系思想落地不畅。第二重困境是大小体系融合瓶颈。第三重困境是“小体系”运营梗阻。 第二部分:体系矛盾是突围之障一是数据孤岛的障碍。二是投入不足的障碍。三是新旧兼容难的障碍。 第三部分&am…...
无人机侦测与反制技术的进展与应用
国家电网无人机侦测与反制技术的进展与应用 引言 随着无人机(无人驾驶飞行器,UAV)技术的快速发展,其在商业、娱乐和军事领域的广泛应用带来了新的安全挑战。特别是对于关键基础设施如电力系统,无人机的“黑飞”&…...
Golang——6、指针和结构体
指针和结构体 1、指针1.1、指针地址和指针类型1.2、指针取值1.3、new和make 2、结构体2.1、type关键字的使用2.2、结构体的定义和初始化2.3、结构体方法和接收者2.4、给任意类型添加方法2.5、结构体的匿名字段2.6、嵌套结构体2.7、嵌套匿名结构体2.8、结构体的继承 3、结构体与…...
