Web 事务管理

news2024/12/26 21:38:33

Web在执行的过程中需要保证一致性,从而需要引入事务来对SQL事件进行事务的管理。具体而言可以参考这篇博客MySQL事务(transaction)。

具体而言,我们获得一个这样的需求,删除一个部门,在删除部门的过程中需要删除部门下的所有员工

@Override
public void delete(Integer id)
    {
        // 由于这里要执行两端删除代码,为了保证一致性
        // 外面使用事务的方法进行封装与回滚
        deptMapper.delete(id);
        empMapper.deleteEmpByDeptId(id);
    }

正常而言这段代码是可以正常执行的,但是我们在中间引入一个错误,即在两个请求过程中加入一个运行时错误,此时deptMapper.delete(id);执行成功,empMapper.deleteEmpByDeptId(id);执行失败,这时部门删除了,但是该部门下的所有员工并没有删除(这就导致了数据库的不一致性)。

    @Override
    @Transactional
    public void delete(Integer id)
    {
        // 由于这里要执行两端删除代码,为了保证一致性
        // 外面使用事务的方法进行封装与回滚
        deptMapper.delete(id);
        int i =1/0;
        empMapper.deleteEmpByDeptId(id);
    }

SpringBoot中的事务管理

为此我们引入SpringBoot中的事务管理,它是通过@Transactional进行注解标注的,有个这个注解整个函数包裹的部分变成一个事务。
在这里插入图片描述

    @Override
    @Transactional
    public void delete(Integer id)
    {
        // 由于这里要执行两端删除代码,为了保证一致性
        // 外面使用事务的方法进行封装与回滚
        deptMapper.delete(id);
        int i =1/0;
        empMapper.deleteEmpByDeptId(id);
    }

为了观察到日志,我们在application.yml引入事务管理日志。

logging:
  level:
    org.springframework.jdbc.support.jdbtTransactionManager: debug

执行上述代码可以看到:
运行时错误,同时整个事务进行了回滚。(同时数据库中的两个表都没有进行删除)
在这里插入图片描述

事务管理——rollbackFor

默认情况下@Transactional只会在系统出现运行时错误(RuntimeException)才会回滚(1/0操作就是典型的运行时错误)。
像下面,如果我们自己定义一个异常,事务是不会出现回滚的。

    @Override
    @Transactional
    public void delete(Integer id) throws Exception
    {
        // 由于这里要执行两端删除代码,为了保证一致性
        // 外面使用事务的方法进行封装与回滚
        deptMapper.delete(id);
        if(true)
        	throw new Exception("一个错误");
        empMapper.deleteEmpByDeptId(id);
    }

为此我们就需要引入rollbackFor,来定义回滚时的错误。

@Transactional(rollbackFor = Exception.class)

在注解上添加rollbackFor = Exception.class,告诉事务,遇见所有异常我都要进行回滚。

事务管理——propagation 事务传播行为

事务传播行为:指的是一个事务方法被另一个事务方法调用时,这个事务方法应该如何进行事务控制。
主要有这些事务属性
在这里插入图片描述
一般而言,我们知道两个就行REQUIRED、REQUIRES_NEW。
在这里插入图片描述

例如我这里的需求是解散部门,同时无论成功失败,都需要将记录写在操作日志上
那我们的步骤就总共为两部:1.解散部门和员工、2.记录日志到数据库

@Override
    @Transactional(rollbackFor = Exception.class)
    public void delete(Integer id) throws Exception
    {
        // 由于这里要执行两端删除代码,为了保证一致性
        // 外面使用事务的方法进行封装与回滚

        try {
            deptMapper.delete(id);
            int i = 1/0;
            empMapper.deleteEmpByDeptId(id);
        }
        finally {

            LocalDate createTime = LocalDate.now();
            String description = "执行了解散部门的操作,解散的部门为"+id;
            deptMapper.insertDeptLog(createTime,description);
        }
        
    }

日志记录我们这里也是一个@Transactional注解的方法

@Transactional
public void insertDeptLog(LocalDate createTime,String description);

将这个记录的方法放在了finally {}中,无论成功失败我们都要执行,但是操作这个代码发现,日志上并没有记录。
原因是这两个@Transactional默认都是REQUIRED类型,首先执行void delete(Integer id) throws Exception代码,其自动为自己创建一个Transactional;当执行到finally {}中的void insertDeptLog(LocalDate createTime,String description)时候,insertDeptLog发现目前自己已经在一个事务中运行了,则不会创建新的事物,这导致两端代码同时回滚。

为了解决这个问题,则需要对insertDeptLog中注解声明参数REQUIRES_NEW,告诉系统,无论外面有没有事物,我都会自己创建一个事物。

    @Transactional(propagation = Propagation.REQUIRES_NEW)
    public void insertDeptLog(LocalDate createTime,String description);

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

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

相关文章

无人机航管应答机 ping200XR

产品概述 ping200XR是一个完整的系统,旨在满足航管应答器和自动相关监视广播(ADS-B)的要求,在管制空域操作无人航空系统(UAS)。该系统完全可配置为模式A,模式C,模式S转发器和扩展ADS-B发射机的任何组合。ping200XR包括一个精度超…

几个Web自动化测试框架的比较:Cypress、Selenium和Playwright

介绍:Web自动化测试框架对于确保Web应用程序的质量和可靠性至关重要。它们帮助开发人员和测试人员自动执行重复性任务,跨多个浏览器和平台执行测试,并在开发早期发现问题。 以下仅代表作者观点: 本文探讨来3种流行的Web自动化测…

怎么把视频转换成mp4格式?分享几种视频格式转换方法

将视频格式转换成MP4格式的好处包括:更广泛的兼容性,因为MP4是一种通用格式,大多数设备和平台都支持;更小的文件大小,因为MP4使用高效的压缩算法,可以将视频文件压缩到更小的大小;更好的视频质量…

Linux常用命令——diff3命令

在线Linux命令查询工具 diff3 比较3个文件不同的地方 补充说明 diff3命令用于比较3个文件,将3个文件的不同的地方显示到标准输出。 语法 diff3(选项)(参数)选项 -a:把所有的文件都当做文本文件按照行为单位进行比较,即给定的文件不是文…

element-ui中二次封装一个带select的form组件

带select的form组件 样式 代码 <template><el-form-item label"是否有" class"append" prop"tag"><el-form-itemprop"isShare"><el-select v-model"query.tag"><el-option v-for"(item, …

Shell编程基础02

0目录 1.case语法 2.grep 3.sed 4.awk 5.linux安装mysql 1.case语法 创建一个txt文档 执行 查询用户名 case 用法 写一个计算器脚本 加入函数 补充查看进程命名 2.find grep命令 Find 查询当前目录下 以sh结尾的文件 Grep 查询义开头的 或者加入正则表达…

AIGC 施展“物理魔法”,3D视觉突破“精度极限”

点击关注 文&#xff5c;姚悦&#xff0c;编&#xff5c;王一粟 “没有艺术&#xff0c;全是物理&#xff01;物理让你快乐&#xff0c;不是吗&#xff1f;” 近日&#xff0c;在世界计算机图形会议 SIGGRAPH 2023 上&#xff0c;英伟达创始人、CEO 黄仁勋宣布&#xff0c;将…

小型便携式气象站的功能特点

小型便携式气象站是一种&#xff0c;集多种传感器和自动化功能于一体的气象观测设备&#xff0c;具有便携性和自动化的特点。能够自动测量和记录各项气象参数&#xff0c;为人们提供实时气象数据。 小型便携式气象站的功能特点如下&#xff1a; 1.小型便携式气象站轻便便携&a…

秒懂算法│博弈论

博弈论是二人或多人在平等的对局中各自利用对方的策略变换自己的对抗策略,达到取胜目标的理论。博弈论是研究互动决策的理论。博弈可以分析自己与对手的利弊关系,从而确立自己在博弈中的优势,因此有不少博弈理论,可以帮助对弈者分析局势,从而采取相应策略,最终达到取胜的目的。…

StreamingWarehouse的一些思考和未来趋势

300万字&#xff01;全网最全大数据学习面试社区等你来&#xff01; 一篇笔记。 以Hudi、Iceberg、Paimon这几个框架为例&#xff0c;它们支持高效的数据流/批读写、数据回溯以及数据更新。具备一些传统的实时和离线数仓不具备的特性&#xff0c;主要有几个方面&#xff1a; 这…

【30天熟悉Go语言】10 Go异常处理机制

作者&#xff1a;秃秃爱健身&#xff0c;多平台博客专家&#xff0c;某大厂后端开发&#xff0c;个人IP起于源码分析文章 &#x1f60b;。 源码系列专栏&#xff1a;Spring MVC源码系列、Spring Boot源码系列、SpringCloud源码系列&#xff08;含&#xff1a;Ribbon、Feign&…

2023国赛数学建模A题B题C题D题资料思路汇总 高教社杯

本次比赛我们将会全程更新思路模型及代码&#xff0c;大家查看文末名片获取 之前国赛相关的资料和助攻可以查看 2022数学建模国赛C题思路分析_2022年数学建模c题思路_UST数模社_的博客-CSDN博客 2022国赛数学建模A题B题C题D题资料思路汇总 高教社杯_2022国赛a题题目_UST数模…

三维模型OSGB格式轻量化的数据压缩与性能平衡分析

三维模型OSGB格式轻量化的数据压缩与性能平衡分析 在三维模型应用中&#xff0c;OSGB格式轻量化处理是一种常见的技术手段&#xff0c;它可以通过数据压缩、简化、滤波等操作&#xff0c;降低三维模型数据的存储空间和传输带宽需求&#xff0c;提高应用程序的性能和用户体验。但…

python35种绘图函数总结,3D、统计、流场,实用性拉满

文章目录 基础图误差线三维图等高线图场图统计图非结构坐标图 基础图 下面这8种图像一般只有两组坐标&#xff0c;直观容易理解。 函数坐标参数图形类别plotx,y曲线图stackplotx,y散点图stemx,y茎叶图scatterx,y散点图polarx,y极坐标图stepx,y步阶图barx,y条形图barhx,y横向条…

中国社科院大学-美国杜兰大学能源管理硕士招生信息详情

中国社科院大学-美国杜兰大学能源管理硕士招生信息详情 金融硕士 中国社科院大学-美国杜兰大学能源管理硕士招生信息详情 能源与气候是21世纪人类所面临的最严峻挑战&#xff0c;当今世界能源格局面临深度调整&#xff0c;全球应对气候变化行动加速&#xff0c;国家间科技竞争…

三维模型OSGB格式轻量化的纹理压缩和质量保持分析

三维模型OSGB格式轻量化的纹理压缩和质量保持分析 在三维模型应用中&#xff0c;纹理数据是一个重要的部分&#xff0c;可以为模型增加更多的真实感和细节。但是&#xff0c;由于纹理数据通常会占用大量的存储空间和传输带宽&#xff0c;因此&#xff0c;在OSGB格式轻量化处理中…

LeetCode.141,142——环形链表,环形链表Ⅱ

LeetCode.141——环形链表&#xff1a; 题目如下&#xff1a; 通过题目中对于环形链表的大体描述&#xff0c;可以知道&#xff0c;环形链表最后一个结点保存了一个地址&#xff0c;用于返回链表中某个结点。并且。这个返回的结点并不是返回图中保存数据的结点。而是返回链表…

0603-指针和函数

函数形参改变实参的值 值传递&#xff0c;形参不影响实参的值 地址传递&#xff0c;形参可以改变实参的值 数组名做函数参数 数组名做函数参数&#xff0c;函数的形参会退化为指针。这里的数组名不仅仅指一维数组的数组名&#xff0c;也包括多维数组的数组名&#xff0c;它们…

数据结构算法--4堆排序

堆排序过程: >建立堆(大根堆) >得到堆顶元素&#xff0c;为最大元素 >去掉堆顶&#xff0c;将堆最后一个元素放到堆顶&#xff0c;此时可通过一次调整使堆重新有序 >堆顶元素为第二大元素 >重复步骤3&#xff0c;直到堆变空 此时是建立堆后的大根堆模型 将…

ssl卸载原理

SSL卸载&#xff0c;也称为SSL解密&#xff0c;是一种将SSL加密数据流卸成非加密的明文数据流的过程。SSL卸载通常在负载均衡器、代理服务器、WAF等设备中实现&#xff0c;可以提高传输效率和安全性。 SSL卸载的原理是将SSL数据流拦截下来&#xff0c;通过设备内置的证书进行解…