【实战场景】@Transactional中使用for update的注意点

【实战场景】@Transactional中使用for update的注意点

  • 开篇词:
  • 干货篇:
      • 知识回顾
      • 注意点
        • 1.锁的范围和粒度:
        • 2.事务的隔离级别:
        • 3.死锁:
        • 4.性能影响:
        • 5.事务的边界:
        • 6.异常处理:
        • 7. 数据库和存储引擎的支持:
        • 8. 测试和验证:
  • 总结篇:
  • 我是杰叔叔,一名沪漂的码农,下期再会!

开篇词:

这次接到一个任务要去实现点赞和取消点赞的功能,看似简单的一个需求,里面要考虑的点还是不少,本次采用的方案是spring的@transactional配合mysql的悲观锁for update去实现

(PS:当然可以去用redis去做,但得考虑后续的数据双向同步问题和顶着快速上线的压力还是选择了悲观锁方案,改动小呀 @_@)

干货篇:

知识回顾

  • @Transactional 是 Spring 框架中的一个非常重要的注解,它用于声明一个方法或类需要被事务管理。当你使用 @Transactional 注解时,Spring 容器会为这个方法或类创建一个代理(proxy),并在调用时应用相应的事务管理逻辑。这意呀着,你可以通过简单的注解来管理事务的边界,包括事务的开始、提交或回滚等,而无需手动编写大量的代码来控制事务。
  • 在MySQL中,FOR UPDATE是一个在SELECT语句中使用的选项,它主要用于在事务处理(Transaction Processing)环境中锁定选中的行,以便进行后续的更新操作。当你在一个事务中执行一个带有FOR UPDATE的SELECT语句时,MySQL会锁定这些行,直到当前事务结束(通过COMMIT或ROLLBACK语句)。这样做的目的是为了防止其他事务修改这些行,从而保持数据的一致性和完整性。

注意点

在Spring框架中使用@Transactional注解时,结合SQL查询中的FOR UPDATE子句,需要注意以下几个方面以确保事务的正确性和性能:

1.锁的范围和粒度:
  • FOR UPDATE会锁定查询到的行,直到当前事务结束。因此,要仔细考虑查询的范围,避免不必要地锁定大量行,这可能会影响到并发性能。
  • 确保你的查询是精确的,只锁定需要修改的行。
2.事务的隔离级别:
  • 不同的隔离级别会影响锁的行为和可见性。例如,在READ COMMITTED隔离级别下,锁通常只在需要时持有,而在SERIALIZABLE隔离级别下,可能会锁定更多的数据以防止幻读。
  • 检查并设置适合你的业务场景的事务隔离级别。
3.死锁:
  • 当多个事务相互等待对方释放锁定的资源时,可能会发生死锁。在使用FOR UPDATE时,尤其要注意避免死锁的发生。
  • 设计事务时,尽量保持事务简短,避免在事务中执行复杂的逻辑或等待用户输入。
  • 如果检测到死锁,MySQL会自动检测并中断其中一个事务以解锁。但是,你应该准备好处理事务回滚的情况,并确保应用能够正确地从失败中恢复。
4.性能影响:
  • 锁定行会增加数据库操作的开销,包括锁的获取、保持和释放。
  • 监控数据库的性能指标,如锁等待时间、锁冲突等,以确保事务处理不会成为性能瓶颈。
5.事务的边界:
  • 确保@Transactional注解正确应用在你的服务层方法上,并且这些方法包含了需要事务支持的数据库操作。
  • 注意不要在同一个事务中调用其他服务层的方法,除非这些方法也标记为@Transactional(这可能会导致不必要的嵌套事务或事务传播问题)。
6.异常处理:
  • 在事务方法中正确处理异常,确保在发生错误时能够回滚事务。
  • 使用Spring的@Transactional注解时,默认情况下,运行时异常和错误会触发事务回滚,而检查型异常则不会。你可以通过rollbackFor和noRollbackFor属性来自定义回滚行为。
7. 数据库和存储引擎的支持:
  • 确保你的数据库和存储引擎支持行级锁(如InnoDB)。
  • 不同的存储引擎在锁的实现和性能上可能会有所不同。
8. 测试和验证:
  • 在开发过程中,对使用@Transactional和FOR UPDATE的代码进行充分的测试,以确保它们按预期工作。
  • 使用压力测试和并发测试来验证事务的性能和稳定性。

总结篇:

通过注意这些方面,你可以更有效地在Spring应用中使用@Transactional和SQL查询中的FOR UPDATE子句,从而确保数据的一致性和应用的性能。

在这里插入图片描述

我是杰叔叔,一名沪漂的码农,下期再会!

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

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

相关文章

【漏洞复现】网神 SecGate 3600 防火墙 sys_export_conf_local_save 任意文件读取

免责声明: 本文内容旨在提供有关特定漏洞或安全漏洞的信息,以帮助用户更好地了解可能存在的风险。公布此类信息的目的在于促进网络安全意识和技术进步,并非出于任何恶意目的。阅读者应该明白,在利用本文提到的漏洞信息或进行相关测…

javaweb学习day5--《HTML篇》Springboot的模块创建、HTML的相关知识点详解

一、前言 从今天开始,就要启动后端的学习了,Springboot会贯穿到底,一定要跟着小编严谨的去搭建Springboot环境,依赖添加的过程可能需要2分钟左右,读者们要耐心等待一下,搭建好Springboot之后才算正式的开始…

算力革命:弹性租赁,解锁无限可能

华为创始人任正非曾在一场程序设计竞赛中说道,我们即将进入第四次工业革命,基础就是大算力。事实上,随着5G、人工智能等信息技术的迅猛发展,算力需求持续增长,但高昂的成本和快速的技术迭代让许多中小企业和个人开发者…

Covalent Network(CXT)通过社区投票将代币迁移并更名为 CXT,以推动人工智能更深层次的创新

专注于人工智能和 Web3 的模块化数据基础设施 Covalent Network(CXT)宣布,其治理提案已通过社区投票并顺利实施,即将原生代币 CQT 迁移为新的 CXT 代币,并部署至新的合约。这一关键性转变标志着 Covalent Network&…

springboot文达办公物资管理系统-计算机毕业设计源码51191

摘要 本文介绍了一种名为"文达办公物资管理系统"的基于JAVA语言、基于Springboot框架和MYSQL数据库开发的管理系统。该系统主要分为管理员和员工用户两个角色,以满足不同用户的需求。 对于管理员用户,系统提供了仪器设备管理、设备借用管理、设…

【大数据技术】换新电脑了,如何快速迁移MySQL到新电脑上(含程序+数据),这样既快速又高效,省去了“各种安装+各种配置+各种迁移数据”带来的麻烦和时间

【大数据技术】换新电脑了,如何快速迁移MySQL到新电脑上(含程序数据 背景步骤总结 背景 很久没有写博文了哦,最近我换了新的笔记本,于是需要在新笔记本电脑上搭建MySQL环境,因为我原电脑上是安装的MySQL解压版,故我想偷偷懒&…

可理解性评估:使用Google Gemini优化语音识别的意义保留

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…

实验1 —— 安全策略的练习

实验拓扑图 实验要求 1.DMZ区内的服务器,办公区仅能在办公时间内(9:00-18:00)可以访问,生产区的设备全天可以访问; 2.生产区不允许访问互联网,办公区和游客区允许访问互联网 3.办公区…

动手学Avalonia:基于硅基流动构建一个文生图应用(一)

文生图 文生图,全称“文字生成图像”(Text-to-Image),是一种AI技术,能够根据给定的文本描述生成相应的图像。这种技术利用深度学习模型,如生成对抗网络(GANs)或变换器(T…

【Mac】Charles for Mac(HTTP协议抓包工具)及同类型软件介绍

软件介绍 Charles for Mac 是一款功能强大的网络调试工具,主要用于HTTP代理/HTTP监视器。以下是它的一些主要特点和功能: 1.HTTP代理:Charles 可以作为HTTP代理服务器,允许你查看客户端和服务器之间的所有HTTP和SSL/TLS通信。 …

金航标kinghelm宋仕强在介绍自己公司时说

金航标kinghelm宋仕强在介绍自己公司时说,金航标成立于2007年,成立地点在华强北雷圳大厦803室,后搬到华强北广业大厦24楼CD室,后搬迁到龙华展滔科技大厦C座C809和C817室,现在的办公地址为龙岗区坂田街道百瑞达大厦&…

PageDTO<T>,PageQuery,BeanUtils,CollUtils的封装

一、PageDTO<T> import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.fasterxml.jackson.annotation.JsonIgnore; import com.tianji.common.utils.BeanUtils; import com.tianji.common.utils.CollUtils; import com.tianji.common.utils.…

C#中的MD5摘要算法与哈希算法

文章目录 一、哈希算法基础二、MD5 算法原理三、MD5摘要算法四、哈希算法五、C#实现示例MD5算法示例哈希算法示例字符串MD5值对比 六、总结 一、哈希算法基础 哈希算法是一种单向密码体制&#xff0c;它将任意长度的数据转换成固定长度的字符串。这种转换是不可逆的&#xff0…

IDEA中配置代理,解决Codearts Snap登陆不了的问题

问题描述&#xff1a;在mac电脑中的idea中安装了华为的codearts snap插件&#xff0c;一直登录不了&#xff0c;账号是没问题的&#xff0c;后来我怀疑是我的代理有问题&#xff0c;找到IDEA中的代理设置先是有这个问题“You have JVM property "https.proxyHost" se…

千呼新零售2.0分销商城视频介绍

千呼新零售2.0系统是零售行业连锁店一体化收银系统&#xff0c;包括线下收银线上商城连锁店管理ERP管理商品管理供应商管理会员营销等功能为一体&#xff0c;线上线下数据全部打通。 适用于商超、便利店、水果、生鲜、母婴、服装、零食、百货、宠物等连锁店使用。 详细介绍请…

Android初学者书籍推荐

书单 1.《Android应用开发项目式教程》&#xff0c;机械工业出版社&#xff0c;2024年出版2.《第一行代码Android》第二版3.《第一行代码Android》第三版4.《疯狂Android讲义》第四版5.《Android移动应用基础教程&#xff08;Android Studio 第2版&#xff09;》 从学安卓到用安…

【机器学习】支持向量机与主成分分析在机器学习中的应用

文章目录 一、支持向量机概述什么是支持向量机&#xff1f;超平面和支持向量大边距直觉 二、数据预处理与可视化数据集的基本信息导入必要的库加载数据集数据概况数据可视化特征对的散点图矩阵类别分布条形图平均面积与平均光滑度的散点图变量之间的相关性热图 三、模型训练&am…

在conda的环境中安装Jupyter及其他软件包

Pytorch版本、安装和检验 大多数软件包都是随Anaconda安装的&#xff0c;也可以根据需要手动安装一些其他软件包。 目录 创建虚拟环境 进入虚拟环境 安装Jupyter notebook 安装matplotlib 安装 pandas 创建虚拟环境 基于conda包的环境创建、激活、管理与删除http://t.cs…

podman 替代 docker ? centos Stream 10 已经弃用docker,开始用podman了!

&#x1f468;‍&#x1f393;博主简介 &#x1f3c5;CSDN博客专家   &#x1f3c5;云计算领域优质创作者   &#x1f3c5;华为云开发者社区专家博主   &#x1f3c5;阿里云开发者社区专家博主 &#x1f48a;交流社区&#xff1a;运维交流社区 欢迎大家的加入&#xff01…

浅谈React

forwardRef和useImperativeHandle的联动使用 import React, { useImperativeHandle, useRef } from "react" import { forwardRef } from "react"const CustomInput forwardRef((props, ref) > {const inputRef useRef<HTMLInputElement>(null…