springboot事务操作

事务操作

事务处理就是将一个方法中的全部操作当初一个整体,如果其中一个地方报出异常,我们就需要回滚回之前的操作,防止数据混乱,数据缺失

1、@Transactional

springboot为我们提供了@Transactional注解,该注解可以用于管理一个方法,一个类,一个接口,但是我们一般只使用它来管理一个方法即可,因为需要用到事务操作的一般也就是增删改这些操作
在这里插入图片描述

该注释在方法开始前会开启事务,在函数末尾会提交/回滚事务

2、事务传播

事务传播简单理解就是我对一个方法使用创建了一个事务,但是呢,该方法里面的一个函数同样创建了一个事务,这时我们就需要考虑合并为一个事务,还是分别是独立的事务等问题

springboot提供了事务的一系列操作

在这里插入图片描述

其中,我们只需要重点关注两个属性

假设这里有两个函数,函数A和函数B,函数A里面调用了函数B,假设两个都有事务

  • REQUIRED 这个为Transactional的默认值,如果函数A有创建事务,那么函数B归并到函数A的事务中,如果函数A回滚了,那么函数B的操作也回滚
  • REQUIRES_NEW:这个与REQUIRED不同,两个事务互为独立事务,即使函数A回滚了,但是函数B实现的操作不会回滚,听起来很鸡肋是吧,不会滚我还使用事务干嘛,别急,下面就举例场景

在这里插入图片描述

在这个场景中,无论解散部门成功与否都需要将日记记录下来,这里我们将记录日记的操作理解为上述的函数B的操作,删除部门的操作为函数A的操作

相关函数实现

  • 函数A
    @Transactional@Overridepublic void deleteDeptById(Integer id) {try {deptMapper.deleteDeptById(id);// 删除部门后,将部门的所有员工删除int i = 1 / 0;//我们设计一个异常的情况empMapper.deleteEmpsByDeptId(id);// 无论是否删除成功 都要添加日记到数据库表中} finally {DeptLog deptLog = new DeptLog();deptLog.setCreateTime(LocalDateTime.now());deptLog.setDescription("执行了删除部门操作,此次删除的部门是" + id + "号部门");deptLogService.insert(deptLog);}}
  • 函数B

        @Transactional(propagation = Propagation.REQUIRES_NEW)@Overridepublic void insert(DeptLog deptLog) {deptLogMapper.insert(deptLog);}
    

让我们分析一下,如果使用REQUIRED的情况,我们将函数A和函数B合并到一个事务(函数A的事务中),这时,在执行int i = 1 / 0;时报出了一个错误,那么函数A的事务必须回滚,即使函数B在finally中已经写好了数据,但还是没有,照样回滚,日记没有写入到数据表中,如果我们使用REQUIRES_NEW,A和B是两个独立的事务,在调用函数B时,函数A的事务被挂起,如果函数B执行成功并提交,即使抛出异常导致外层事务回滚,函数B的事务也不会回滚,意思就是说函数a回滚的范围并不包括函数b。

这里我们可以看出,事务的回滚并不是一定要回滚全部操作,我认为使用事务回滚的重要原因是:只有缺乏某方法会导致数据异常,导致数据混乱时才有必要使用回滚,如果某方法与主事务的数据毫不相干,互相独立,就没有必要进行回滚,这与事务回滚的初衷相符且增加了事务回滚的灵活性,所以REQUIRES_NEW的出现我觉得是非常合理的

从这里我们也可以看出使用REQUIRES_NEW的场景

​ 使用 REQUIRES_NEW 时,需要确保新事务中的操作不会对主事务中的操作产生冲突或导致数据不一致。这通常意味着新事务中的操作是独立的、只读的或与主事务操作无关。

3、事务回滚的注意事项

@Transactional事务回滚默认只回滚RuntimeException异常(运行时异常),其他异常不会回滚,我们需要设定@Transactional的rollbackFor来回滚所有异常

    // Transactional 事务管理@Transactional(rollbackFor = Exception.class)@Overridepublic void deleteDeptById(Integer id) {try {deptMapper.deleteDeptById(id);// 删除部门后,将部门的所有员工删除empMapper.deleteEmpsByDeptId(id);// 无论是否删除成功 都要添加日记到数据库表中} finally {DeptLog deptLog = new DeptLog();deptLog.setCreateTime(LocalDateTime.now());deptLog.setDescription("执行了删除部门操作,此次删除的部门是" + id + "号部门");deptLogService.insert(deptLog);}}

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

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

相关文章

2-5 基于matlab的信号的希尔伯特-黄变换

基于matlab的信号的希尔伯特-黄变换,IMF分解,对IMF进行Hilbert处理,绘制二维/三维时-频图,时间-能量图(瞬时能量谱) ,频率-能量图(希尔伯特谱)。程序已调通,可直接运行。 2-5 希尔伯…

Bytebase 2.19.0 - 支持 DynamoDB

Bytebase 2.19.0 支持 DynamoDB 支持独立的 SQL 审核工单。 支持为工单事件配置 Slack 私信通知。 file 支持 PostgreSQL 的 DML 变更事前备份。 为 SQL Server 添加 SQL 审核规则:禁止冗余索引。 重大变更 创建多数据库工单时,不同数据库会共享同…

python pandas处理股票量化数据:笔记2

有一个同学用我的推荐链接注册了tushare社区帐号https://tushare.pro/register?reg671815,现在有了170分积分。目前使用数据的频率受限制。不过可以在调试期间通过python控制台获取数据,将数据保存在本地以后使用不用高频率访问tushare数据接口&#xf…

Mybatis用Map接收返回值可能出现的问题

先看一个示例 明明定义了Map<String,String> 实际内部存放的是Integer resultType是Map 也就是说Mybatis是通过反射将类型放进去的 躲过了编辑器检查 但是这样取值时候就会报类型转换错误 解决方式 resultMap 另外一种方式 用Number Integer和Double的父类 Ma…

Excel/WPS《超级处理器》功能介绍与安装下载

超级处理器是基于Excel或WPS开发的一款插件&#xff0c;拥有近300个功能&#xff0c;非常简单高效的处理表格数据&#xff0c;安装即可使用。 点击此处&#xff1a;超i处理器安装下载 Excel菜单&#xff0c;显示如下图所示&#xff1a; WPS菜单显示&#xff0c;如下图所示&am…

15.混合专家模型(MoEs)技术揭秘

混合专家模型&#xff08;MoEs&#xff09;技术揭秘 混合专家模型&#xff08;Mixture-of-Experts, MoEs&#xff09;技术发展简史 Mixtral 8x7B &#xff1a;质效并举的稀疏混合专家模型 Mixtral 8x7B &#xff1a;质效并举的稀疏混合专家模型 MoEs 技术发展简史 MoEs 开山…

matplotlib twinx多y轴但单个图例

matplotlib 用 twinx 画多 y 轴参考 [1]。现想在画图例时&#xff0c;多个 y 轴的图例画在一起&#xff0c;写法参考 [2]。本文展示一个简例&#xff0c;效果&#xff1a; Code 要手动指定颜色&#xff0c;否则原 y 轴的用色和新 y 轴会重合。 import matplotlib.pyplot as…

永磁同步直线电机(PMLSM)控制与仿真2-永磁同步直线电机数学模型搭建

文章目录 1、公式总结2、电压方程模型3、运动方程4、推力方程5、转化关系 写在前面&#xff1a;原本为一篇文章写完了永磁同步直线电机数学模型介绍&#xff0c;永磁同步直线电机数学模型搭建&#xff0c;以及永磁同步直线电机三环参数整定及三环仿真模型搭建&#xff0c;但因为…

TCP及UDP协议

tcp是点到点的&#xff0c;只有一条路径&#xff0c;到达顺序和发送顺序是相同的 回复的确认号是序发送端的序列号加上data的长度 1910 发送端的序列号也是那么算的 ack和下一个seq一样 那就没问题 三次握手四次挥手&#xff1a; 为啥是三次呢&#xff1f; 假如一次&#xf…

关于Linux ping 不通外网

网关为第三段为137那么子网ip第三段必须为137且IPaddr必须为137 将主机虚拟适配器连接到此网络必须勾上&#xff0c;不然vmnet适配器在windows将找不到 ping www.baidu.com不行的话试着勾上桥接模式应该是不行在勾上取消勾上桥接模式最后勾上nat模式

【2024亲测无坑】在Centos.7虚拟机上安装Oracle 19C

目录 一、安装环境准备 1、linux虚拟机安装 2、虚拟机快照 3、空间检查&软件上传 二、Oracle软件安装 1.preinstall安装及其他配置准备 2.oracle安装 三、数据库实例的安装 1.netca——网络配置助手 2.dbca——数据库配置助手 四、ORACLE 19C 在linux centos 7上…

Linux rm命令由于要删的文件太多报-bash: /usr/bin/rm:参数列表过长,无法删除的解决办法

银河麒麟系统&#xff0c;在使用rm命令删除文件时报了如下错误&#xff0c;删不掉&#xff1a; 查了一下&#xff0c;原因就是要删除的文件太多了&#xff0c;例如我当前要删的文件共有这么多&#xff1a; 查到了解决办法&#xff0c;记录在此。需要使用xargs命令来解决参数列表…

誉天教育近期开班计划(6月15日更新)

云计算HCIP 周末班 2024/6/15 田老师 售前IP-L3 周末班 2024/6/15 陈老师 RHCA442 晚班 2024/6/17邹老师 数通HCIE 晚班 2024/6/24阮老师 云计算HCIE直通车晚班 2024/6/25 曾老师 售前IT-L3 周末班 2024/6/29 伍老师 数通HCIP 晚班 2024/7/1杨老师 存储直通车 晚班 2024/7/1 高…

【NoSQL数据库】Redis Cluster集群(含redis集群扩容脚本)

Redis Cluster集群 Redis ClusterRedis 分布式扩展之 Redis Cluster 方案功能数据如何进行存储 redis 集群架构集群伸缩向集群中添加一个新的master节点&#xff0c;并向其中存储 num10 .脚本对redis集群扩容缩容&#xff0c;脚本参数为redis集群&#xff0c;固定从6001移动200…

了解统计学中不同类型的分布

目录 一、说明 二、均匀分布&#xff1a; 三、机器学习和数据科学中的均匀分布示例&#xff1a; 3.1 对数正态分布&#xff1a; 3.2 机器学习和数据科学中的对数正态分布示例&#xff1a; 四、 帕累托分布 4.1 什么是幂律&#xff1f; 4.2 机器学习和数据科学中的帕累托分布示例…

如何清除anaconda3缓存?

如果长期使用anaconda不清理缓存&#xff0c;会导致anaconda占用磁盘空间越来越多&#xff0c;甚至系统磁盘撑爆。 清除包缓存&#xff1a; 打开 Anaconda Prompt 或者命令行窗口。运行以下命令清除包缓存&#xff1a;conda clean --all这会清除所有的包缓存&#xff0c;释放磁…

docker下载ridis

1、执行 docker pull redis:4.0.1 命令&#xff0c;下载 redis 镜像 &#xff08;需确保装有并启动bocker&#xff09; 通过docker启动redis 分配端口和端口映射 密码等 rootiZf8z985hmyc9bkejcfmqrZ:~# docker run --rm -d --name redis6379 -p 6379:6379 redis:4.0.1 --req…

1.个人博客系统项目

一、项目介绍 个人博客系统 相关技术&#xff1a; SpringBootSpringMvcMybatisMysqlRedis项目简介&#xff1a;本项目为一个功能完善的个人博客系统&#xff0c;支持文章的编辑、修改、删除和发布&#xff0c;以及作者个人信息的展示等功能。项目描述&#xff1a; 采用前后端…

利用钉钉机器人和PHP开发一款免费的网站可用性检测工具,单节点版

前言 手里有几套系统正在运维&#xff0c;需要保障正常运行&#xff0c;所以可用性检测就必不可少啦&#xff0c; 以前本来是用的阿里官方的云监控&#xff0c;但现在价格感觉太贵了&#xff0c;不划算 那就自己手搓一个简易版的监控吧。 成品效果展示 代码展示 <?php …

微信小程序毕业设计-实验室管理系统项目开发实战(附源码+论文)

大家好&#xff01;我是程序猿老A&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 &#x1f49e;当前专栏&#xff1a;微信小程序毕业设计 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f380; Python毕业设计…