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

news2024/9/25 7:15:25

【实战场景】@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.coloradmin.cn/o/1914941.html

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

相关文章

Xinstall揭秘:APP推广数据背后的真相,让你的营销更精准!

在这个移动互联网时代,APP如同雨后春笋般涌现,但如何在这片红海中脱颖而出,成为每一个开发者与运营者面临的共同难题。其中,APP推广统计作为衡量营销效果、优化推广策略的关键环节,更是不可忽视的一环。今天&#xff0…

【java计算机毕设】学生项目竞赛管理系统 MySQL ssm JSP maven小组项目设计代码源码+万字文档

目录 1项目功能 2项目介绍 3项目地址 1项目功能 【java计算机毕设】学生项目竞赛管理系统 MySQL ssm JSP maven小组项目设计代码源码万字文档 2项目介绍 系统功能: 学生项目竞赛管理系统包括管理员、用户、教师三种角色。 管理员功能包括个人中心模块用于修改个…

JS进阶-构造函数

学习目标: 掌握构造函数 学习内容: 构造函数 构造函数: 封装是面向对象思想中比较重要的一部分,js面向对象可以通过构造函数实现的封装。 同样的将变量和函数组合到了一起并能通过this实现数据的共享,所不同的是借助…

SA8317E单通道 2.7-15.0V 持续电流 2.5A H 桥驱动芯片

描述 SA8317E 是为消费类产品,小家电和其他 低压或者电池供电的运动控制类应用提供 了一个集成的电机驱动器解决方案。此器 件能够驱动一个直流电机,由一个内部电 荷泵生成所需的栅极驱动电压电路和 4 个 功率 NMOS 组成 H 桥驱动,集成了电…

机器学习和AI智能写作对未来文案编辑的影响

欢迎关注小知:知孤云出岫 目录 机器学习和AI智能写作对未来文案编辑的影响1. 简介2. AI智能写作工具的现状3. AI智能写作的优势3.1 提高效率3.2 降低成本3.3 数据驱动的个性化 4. AI智能写作的挑战4.1 创造力和独创性4.2 道德和伦理问题4.3 技术限制 5. 行业变化5.…

scss概念及使用

目录 scss是什么 scss和css比较 scss的使用 声明变量 区分默认变量 区分全局变量和局部变量 嵌套语法 选择器嵌套 基本嵌套 嵌套中的父选择器引用(&) 嵌套的注意事项 嵌套的嵌套 属性嵌套 基本属性嵌套 嵌套的注意事项 继承 基本用…

python学习-错误与异常

代码是人的逻辑思维的具体体现,因为没有一个人的逻辑思维是完美无缺的,所以人在编写代码时必然会出现各种错误。既然错误或多或少都会发生,那么如何捕捉错误,并且捕捉到错误后要如何处理,就显得很重要。 语法错误 Py…

Win10屏幕录制,这3种方法分享给你

数字化时代里,电脑的屏幕录制功能已经不再是简单的工具,而是成为我们表达、学习和交流的重要媒介。Win10系统依然是大部分人使用的电脑系统,那么关于Win10屏幕录制,有哪些好用高效的录制软件,能够帮助我们更加深入地捕…

【postgresql】视图(View)

PostgreSQL 中的视图(View)是一种虚拟表,其内容由 SQL 查询定义。视图可以简化复杂的 SQL 操作,使得用户能够以一种更直观、更易于理解的方式来访问和操作数据。 PostgreSQL 视图是只读的,因此可能无法在视图上执行 D…

【JavaEE】进程

目录 一.冯诺依曼体系结构 二.CPU的核心概念 核心数 频率(Clock Speed 或时钟频率) 如何选择合适的CPU 三.指令的执行 1.什么是指令 1.取指令 2.解析指令 3.执行指令 4.访问内存(Memory): 5.写回结果(Write…

回收站删除了是不是彻底删除了 回收站删除了怎么找回 回收站删除了还能找回来吗

电脑删除的数据文件一般不会直接被彻底删除掉,而是会暂存在回收站中,这样设计主要是为了防止误删除等操作,如果不小心删除了很重要的文件,只需要在回收站对文件进行还原即可。为了让大家更了解回收站,下面给大家详细讲…

在生产环境中打印堆栈信息以排查错误

个人名片 🎓作者简介:java领域优质创作者 🌐个人主页:码农阿豪 📞工作室:新空间代码工作室(提供各种软件服务) 💌个人邮箱:[2435024119qq.com] &#x1f4f1…

我们以后坐出租车,是不是都是没司机了?

今天看到一篇帖子 说是广州出现了一种无人驾驶的出租车 确实比较新奇 萝卜快跑 自动驾驶,不是一个新概念了 其实技术已经很成熟了 但是可能因为法律的一些原因 一直没有全面推 在加上现在AI大模型这块,很火 AI自动驾驶 从打车 到接客 再到送到目的地 一…

亚马逊erp跟卖采集之关键词采集

大家好,今天讲这款erp的跟卖采集关键词采集。 打开erp跟卖功能采集任务,点新增任务站点美国,有5种采集方式:关键词、店铺链接、类目ASIN。 选择关键词采集,这里我选择女童装,选择女童板鞋复制粘贴。页数我…

在2018.3没有找到对应的器件库,需要

图中的器件在vivado中没有找到 一、添加器件 发现所有的2018.3的所有器件库,其实都已经安装了,那么意味着2018.3没有办法对该器件进行综合。 二、安装更新版本的vivado 重新安装的2022.2,在选择器件的时候,把所有的器件全部勾选…

关于string的‘\0‘与string,vector构造特点,反迭代器与迭代器类等的讨论

目录 问题一:关于string的\0问题讨论 问题二:C标准库中的string内存是分配在堆上面吗? 问题三:string与vector的capacity大小设计的特点 问题四:string的流提取问题 问题五:迭代器失效 问题六&#xf…

最后纪元Last Epoch可以通过什么搬砖 游戏搬砖教程

来喽来喽,最后纪元,一款《最后纪元》是一款以获得战利品为基础的暗黑风格动作RPG游戏,玩家将从2281年的毁灭时代追溯到由女神Eterra创造的世界,通过多个时代与黑暗的命运对抗,找到拯救世界的方式。游戏有五种职业&…

AI赛道成功的“小”AI平台,都在做什么?

在深入了解30多家跨界拓展AI赛道业务的企业后,我们发现大家对目前的AI市场存在一定程度的误解:即认为在AI领域想要分一杯羹,只需要搞几个API,把大语言模型、绘画、视频、数字人等功能都放上去,可能就有机会占一席之地了…

20240711 每日AI必读资讯

🎨Runway Gen-3 Alpha 详细使用教程以及提示词指南大全 - 7月9日,著名生成式AI平台Runway在官网公布了,最新发布的文生视频模型Gen-3 Alpha的文本提示教程。 - 从技术层面来说,输入的文本提示会被转换成“向量”,这些…

数据开源 | Magic Data大模型高质量十万轮对话数据集

能够自然的与人类进行聊天交谈,是现今的大语言模型 (LLM) 区别于传统语言模型的重要能力之一,近日OpenAI推出的GPT-4o给我们展示了这样的可能性。 对话于人类来说是与生俱来的,但构建具备对话能力的大模型是一项不小的挑战,收集高…