MySQL 的乐观锁和悲观锁是什么?

news/2024/12/15 14:26:53/文章来源:https://www.cnblogs.com/eiffelzero/p/18607958

MySQL 的乐观锁和悲观锁是什么?

在并发环境下,为了避免数据竞争和保证数据一致性,可以使用不同的锁策略。乐观锁和悲观锁是两种常见的并发控制机制,它们在锁定数据时的理念和实现方式上有显著区别。


1. 悲观锁(Pessimistic Lock)

定义

  • 悲观锁是一种保守的并发控制策略,假设数据在被访问时会发生并发修改,因此在操作数据之前会将其锁定,确保其他事务无法修改数据。
  • 使用悲观锁的事务在操作数据时会 主动加锁,以防止其他事务对数据的读写操作。

实现方式

  • 在 MySQL 中,悲观锁通常依赖于数据库的锁机制,例如 行锁表锁
  • 常用语法
    • 使用 SELECT ... FOR UPDATELOCK TABLES 来实现悲观锁。

示例

事务 A 和事务 B 需要修改同一条记录:

  1. 事务 A 执行以下语句:
START TRANSACTION; SELECT * FROM orders WHERE id = 1 FOR UPDATE;

此时,事务 A 加锁,事务 B 无法操作 id = 1 的记录。

  1. 事务 B 尝试修改相同记录时会被阻塞,直到事务 A 提交或回滚。

适用场景

  • 数据冲突较频繁的场景,例如高并发情况下对相同资源的修改操作。
  • 在修改之前需要保证数据的强一致性。

2. 乐观锁(Optimistic Lock)

定义

  • 乐观锁是一种开放的并发控制策略,假设数据在被操作期间不会发生冲突,因此不在操作前加锁,而是在提交数据时通过 冲突检测机制 检测是否存在数据竞争。
  • 如果检测到数据已被其他事务修改,则回滚并重新尝试。

实现方式

  • 乐观锁通常通过 版本号时间戳 来实现。
  • 常用逻辑
  1. 查询数据时,读取记录的版本号或时间戳。
  2. 修改数据时,检查记录的版本号或时间戳是否与查询时一致。
  3. 如果一致,则更新记录并增加版本号;否则,说明数据被其他事务修改,需要重试或终止操作。

示例

表结构如下:

CREATE TABLE orders ( id INT PRIMARY KEY, stock INT, version INT );

事务更新逻辑:

  1. 查询数据:
SELECT stock, version FROM orders WHERE id = 1;
  1. 更新数据:
UPDATE orders SET stock = stock - 1, version = version + 1 WHERE id = 1 AND version = 当前版本号;
  1. 检查受影响的行数:
  • 如果行数为 0,表示版本号已变化,需要重试或终止操作。

适用场景

  • 数据冲突较少的场景,例如读多写少的业务场景。
  • 高并发情况下,提高性能,同时保证一定程度的数据一致性。

3. 乐观锁与悲观锁的对比

对比项 乐观锁 悲观锁
理念 假设冲突很少,操作时不加锁,依赖冲突检测。 假设冲突频繁,操作时加锁,防止冲突发生。
实现方式 依赖版本号、时间戳或 CAS(Compare and Swap)。 使用数据库的锁机制,例如 FOR UPDATE
性能 无锁操作,性能较高,适合高并发场景。 需要加锁,性能较低,适合冲突频繁场景。
冲突检测 提交时检测是否冲突。 通过加锁避免冲突。
适用场景 读多写少,冲突较少的场景。 写多且冲突频繁的场景。

总结

  • 悲观锁 通过锁机制保证操作安全,适合冲突频繁的场景,但性能较低。
  • 乐观锁 依赖版本控制机制来检测冲突,适合冲突较少的高并发场景,性能更优。
  • 在实际开发中,可以根据具体业务需求选择合适的锁机制。例如:
  • 数据一致性要求极高时使用 悲观锁
  • 数据冲突概率较低时使用 乐观锁

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

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

相关文章

2024-2025-1 20241417 《计算机基础与程序设计》第十二周学习总结

2024-2025-1 20241417 《计算机基础与程序设计》第十二周学习总结 作业信息这个作业属于哪个课程 <班级的链接>(如2024-2025-1-计算机基础与程序设计)这个作业要求在哪里 <作业要求的链接>2024-2025-1计算机基础与程序设计第十二周作业这个作业的目标 <复习前…

PbootCMS中如何让后台输入的换行符在前台正确显示?

在PbootCMS中,如果你在后台输入的内容中包含换行符(如 <br>),但前台显示时这些换行符被当作普通文本输出(例如显示为 <br>),你可以通过使用格式化标签来解决这个问题。具体做法是在调用内容的标签中添加 decode=1 参数。例如,如果你原本的代码是 {sort:sub…

如何在PbootCMS中获取搜索页的关键词和搜索结果数量?

在PbootCMS中,你可以通过特定的标签来获取搜索页的关键词和搜索结果的数量。以下是如何使用这些标签的详细说明和一些扩展建议:获取搜索关键词:在搜索页模板search.html中,使用标签{$get.keyword}来获取用户输入的搜索关键词。 例如:html<h1>搜索结果:{$get.keywor…

PbootCMS后台登录验证码看不清怎么办?

在使用PbootCMS时,有时会遇到后台登录验证码看不清的问题。这通常是由于PHP版本不兼容导致的。以下是如何解决这一问题的详细步骤和注意事项。问题原因分析:PHP版本不支持:验证码看不清的问题通常是由于服务器上的PHP版本不支持PbootCMS的验证码生成功能。不同版本的PHP对某…

VS2022 配置openCV方法

第一步下载opencv库解压出来这里不做过多讲解第二步配置环境变量 %path%\build\x64\vc16\bin %path%这个替换成自己的路径 然后打开项目属性设置点击VC++目录 链接器、输入、附件依赖分别添加 前面的是我自己的目录 换成你们自己目录即可 第一步添加 库目录D:\Opencv\ope…

WPF TreeView实现固定表头

1、在WPF中TreeView默认不支持固定表头的我们可以修改样式实现固定表头新建一个TreeListView类 然后继承TreeView代码如下public class TreeListView : TreeView,IDisposable{public TreeListView(){//this.Loaded += TreeListView_Loaded;//this.SizeChanged += TreeListView_…

居家徒手健身

居家徒手健身 力竭组,组间歇2min,动作变形算力竭为一组 第一天:胸+三头 动作: 宽距俯卧撑6组(胸外延) 标准俯卧撑4组胸整体 钻石俯卧撑4组(胸中缝) 板凳臂屈伸4~8组(三头) 第二天:肩 +腿 动作: 折刀俯卧撑6~10组(肩中束) 腰间俯卧撑4~6组 (肩前束) 弹力绳深蹲6组…

个人网站建站日记-集成Markdown编辑器

一次偶然的机会,我体验的到了markdown的便捷,于是乎,我就着手给我的网站闲蛋博客社区集成了Markdown,现在可以自由的切换Markdown与富文本编辑的使用了。这里我特此分享记录下安装使用的过程。 一、安装Markdown编辑器 这里我采用的是md-editor-v3编辑器,目前看来还是很好…

arbitrum 资产桥合约

资产桥的作用 Rollup 的主要流程中,实际上不包含资产桥,也就是说即使没有资产桥,L2依然能正常运行但是此时L1与L2在数据上是完全独立的两条链,L1不理解L2上的数据(L1只保存L2压缩后的数据,不理解数据),L2上也不知道L1上发生了什么(只能拿到区块高度等一些基本信息)。完…

鸿蒙NEXT开发案例:经纬度距离计算

【引言】 在鸿蒙NEXT平台上,我们可以轻松地开发出一个经纬度距离计算器,帮助用户快速计算两点之间的距离。本文将详细介绍如何在鸿蒙NEXT中实现这一功能,通过简单的用户界面和高效的计算逻辑,为用户提供便捷的服务。 【环境准备】 • 操作系统:Windows 10 • 开发工具:De…

C语言中0为假,正数和负数均为真

001、[b20223040323@admin2 test]$ ls test.c [b20223040323@admin2 test]$ cat test.c #include <stdio.h>int main(void) {int i,j,k; ## 三个变量 负数、正数和0i = -5;j = 8;k = 0;if(i){puts("xxxx");}if(j){puts("yyyy");}if(k){puts(&qu…

2024-2025-1(20241321)《计算机基础与程序设计》第十二周学习总结

这个作业属于哪个课程 <班级的链接>(2024-2025-1-计算机基础与程序设计)这个作业要求在哪里 <作业要求的链接>(2024-2025-1计算机基础与程序设计第十二周作业)这个作业的目标 <深刻学习C语言,反思一周学习,温故知新>作业正文 ... 本博客链接https://www.…