Spring的嵌套事务(Propagation.NESTED)到底是个啥

news2025/1/17 15:31:35

什么是嵌套事务

嵌套事务其实是对数据库SavePoint概念的Java操作版封装,什么是SavePoint参考我另一篇blog:juejin.cn/post/718544…

SavePoint是数据库事务中的一个概念, 可以将整个事务切割为不同的小事务, 可以选择将状态回滚到某个小事务发生时的样子。

Propagation.NESTED 则是外部事务的子事务, 如果外部事务 commit, 嵌套事务也会被 commit, 这个规则同样适用于rollback.

嵌套事务开始执行时,  它将取得一个 savepoint, 如果这个嵌套事务失败, 我们将回滚到此 savepoint,嵌套事务是外部事务的一部分, 只有外部事务结束后它才会被提交.

案例

伪代码如下:

ServiceA {  
      
    /** 
     * 事务属性配置为 PROPAGATION_REQUIRED 
     */  
    void methodA() {  
        try {
          DML......
          ServiceB.methodB();  
        } catch(...) ...
        DML....
    }  
  
}  
  
ServiceB {  
      
    /** 
     * 事务属性配置为 PROPAGATION_NESTED 
     */   
    void methodB() {  
    }  
     
}     

如上代码,当methodB开始执行时,spring会在数据库中生成一个SavePoint,methodB失败被spring捕捉到时,会回滚该SavePoint,将methodB中对数据库的操作全部回滚到SavePoint之前,

注意methodA中加入了try catch,引入你的代码如果希望methodB作为一个局部性的事务抛出异常失败后,不影响A的外围事务,那么就不能让异常继续往上抛,否则A这个外围事务也会被全部回滚,因此要在A中自行消化这个异常,

说到这里其实可以总结一下,嵌套事务就是spring像对正常事务一样,帮助我们捕捉SavePoint小事务的异常并进行自动回滚,免去我们在Java代码中使用SavePoint时想要回滚的手动操作,只是前者是一个正常的大事务回滚,后者是大事务中的小事务回滚。

下面是实际测试代码,我们在保存key的时候,也保存一个value,但是保存value时我们抛出exception,并且在保存key的地方catch住:

image.png

image.png

这里是保存前的db,都是空表:

image.png

image.png

操作后,可以看到key表保存进去,value表没保存进去:

image.png

image.png

这里有人会说,key表保存进去是因为我们自己吃了异常,没有被spring捕获到,事务提交了,所以key表保存进去了,value表只是因为被spring捕获到了而已,是不是和嵌套事务没关系?那我们改一下value的事务行为,也使用默认方式,代码如下,并且我们把上面保存进db的数据清空,方便查看效果:

image.png

执行后查看数据库, 空空如也:

image.png

image.png

我们再看log,spring出了一个 Transaction rolled back because it has been marked as rollback-only 的错误,这是什么原因呢? 更改了事务行为后就出现这种,

其实原因很简单,因为两个service都是用默认行为,那么他们同属一个事务,spring检测到了value的方法发生了错误后,会将事务标记为 rollback-only,意味着本次事务发生了错误必须回滚,后续如果尝试提交此事务,就会提示下面的错误信息,

但是我们上面使用嵌套事务时,并没有发生这种情况,因为保存value时,创建了一个SavePoint,spring捕捉到错误后回滚这个SavePoint,并不会将事务标记为错误回滚,后续key地方catch了这个错误,是可以正常提交此事务的。

image.png

SavePoint和嵌套事务在实际应用中场景不多,了解一下如果将来真有需要的话 可以派上用场。

这里有篇文章讲解嵌套事务,推荐一下:www.iteye.com/topic/35907

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/144922.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java图形化界面---AWT布局管理器

目录 一、布局管理器介绍 二、布局管理器用法 (1)FlowLayout (2)BorderLayout (3)GridLayout (4)CardLayout (5)BoxLayout 三、Box容器的讲解 一、布…

自主实现HTTP

"让我们,跳吧在无比宏达的星系!" 一、背景 超文本传输协议(Hyper Text Transfer Protocol,HTTP)是一个简单的请求-响应协议,它通常运行在TCP之上。它指定了客户端可能发送给服务器什么样的消息以及得到什么…

STL list容器底层代码剖析、正向迭代器与反向迭代器的类的封装

目录 一、迭代器是什么 二、迭代器的本质 三、如何给一个容器实现迭代器功能 四、正向迭代器功能的具体实现 五、反向迭代器 六、list底层代码剖析 一、迭代器是什么 迭代器(iterator)有时又称光标(cursor)是程序设计的软件设…

【手写 Vue2.x 源码】第六篇 - 数据代理的实现

一,前言 上篇,主要介绍了 Vue 数据初始化流程中,数组类型的数据劫持是如何实现的,核心思路如下: 出于对性能的考虑,Vue 没有对数组采用 Object.defineProperty 进行递归劫持,而是对能够导致原…

NOSQL数据库习题

NOSQL数据库习题第一章第二章第三章第四章第五章NoSQL数据库上机测试第一章 1.写出DB、RDB、DBMS、TRDB、NoSQL、NewSQL、NDFS的中文名称。 答:DB:数据库 RDB:关系型数据库 DBMS:数据库管理系统 TRDB:传统关系型数据…

解决Shotgrid登陆不上, 上传出错,窗口卡住不动等问题

在使用Shotgrid时,是否遇到这种问题: accounts.autodesk.com出错 auth.autodesk.com出错 再或者这样出错: Shotgrid登陆出错 再再这样关闭Load…时这样出错, 窗口半天都关闭不了: 分析: 1 出现这种错…

(一分钟)激光SLAM扫描匹配 文献阅读

本博客介绍了激光SLAM扫描匹配的相关问题。编辑切换为居中添加图片注释,不超过 140 字(可选)扫描匹配也是数据关联类的问题,是SLAM里面的重要构成部分。编辑切换为居中添加图片注释,不超过 140 字(可选&…

PyTorch实例2——文本情绪分类器

实例主要用于熟悉相关模型,并且练习创建一个模型的步骤:数据收集、数据预处理、构建模型、训练模型、测试模型、观察模型表现、保存模型传送门:蓝桥云课实验 目录1. 实验环境2. 实验目的3. 相关原理4. 实验步骤4.1 数据收集从在线商城抓取评论…

OpenHarmony 标准系统HDF框架之I2C驱动开发

OpenHarmony 标准系统HDF框架之I2C驱动开发主要内容I2C 基础知识## I2C 基础知识 —— 概念和特性I2C 基础知识 —— 协议、四种信号组合I2C 调试手段## I2C 调试手段 —— 硬件I2C 调试手段 —— 软件HDF 框架下的 I2C 设备驱动## HDF 框架下的 I2C 设备驱动 —— 案例描述HDF…

Shell 传递参数

我们可以在执行 Shell 脚本时,向脚本传递参数,脚本内获取参数的格式为:$n。n 代表一个数字,1 为执行脚本的第一个参数,2 为执行脚本的第二个参数,以此类推……实例以下实例我们向脚本传递三个参数&#xff…

ArcGIS Pro脚本工具(15)——按字段属性值分类导图

之前做了配合地图系列批量导图的脚本工具 ArcGIS Pro脚本工具(9)——配合地图系列批量导图_学学GIS的博客-CSDN博客_arcgispro批量导出地图pngPro的地图系列是批量制图的利器,但是有个不便的地方,就是设置完成地图系列后&#xf…

机器学习实战教程(13篇)

机器学习实战教程(13篇)这些网址非常适合想学习机器学习,却苦于没有项目(尤其缺少数据)的人。无意中看到,给自己做一个记录。机器学习实战教程(一):K-近邻算法(史诗级干货长文&#…

2022年度外设产品行业增长分析:鼠标、键盘同比增长27%

近年来,信息技术迅速发展,网民数量不断增长,深刻改变着社会的运作方式,对社会生产、商业运作模式等方面产生重大影响。广泛的行业应用为网络设备品牌商、制造商带来了差异化的细分市场,各类互联网设备接入数量也快速增…

混合空间增强

混合图像增强是一种图像处理技术,用于在不损失图像细节的情况下增强图像的对比度和亮度。它通常通过将图像拆分成多个通道,然后对每个通道进行独立处理来实现。 综合利用平滑滤波,锐化滤波,灰度拉伸等技术对图像进行处理&#xff…

【Linux】sudo给某条指令提权

sudo1.为什么要有sudo2.使用sudo提权的前提2. 在root下添加普通用户到信任列表3.验证4.总结1.为什么要有sudo 首先我们要知道,普通用户是受Linux的权限约束的。就比如普通用户对自己的家目录有完全管理的权限,但是不能随意查看其他人的家目录&#xff0c…

1.机器学习中的关键组件

1.机器学习中的关键组件 无论什么类型的机器学习问题,都会遇到这些组件: 可以用来学习的_数据_(data);如何转换数据的_模型_(model);一个_目标函数_(objective function…

JavaScript 输出

文章目录JavaScript 输出JavaScript 显示数据使用 window.alert()操作 HTML 元素在本教程中写到 HTML 文档写到控制台您知道吗?JavaScript 输出 JavaScript 没有任何打印或者输出的函数。 JavaScript 显示数据 JavaScript 可以通过不同的方式来输出数据: 使用 wi…

TiDB 6.5 LTS 发版

在 2023 伊始,我们很高兴向大家宣布,TiDB 6.5 LTS 版本已经发布了。这是 TiDB V6 的第二个长期支持版(上一个是 TiDB 6.1),除了携带了诸多备受期待的新特性,同时也将得到 TiDB 开发社区的长期维护&#xff…

设计模式(一):DDD领域驱动设计

DDD重架构,轻业务! – 从单体架构开始快速验证DDD设计模式 贫血模型充血模型防腐层 DDD四层架构规范DDD单体架构和微服务架构隔离 本地单体SPI 插拔式扩展业务模式Nacos 插拔式扩展业务模式 ---- 服务名作为服务service code DDD清晰架构 – 构建领域仓库…

加解密与HTTPS(5)

您好,我是湘王,这是我的CSDN博客,欢迎您来,欢迎您再来~咱们大学读完之后有毕业证书,并且这个证书可以在学信网查询。专业上有注会、CCIE、律师证等,可以在国家职业认证机构或委托机构的网站上查…