首页 > 数据库 >乐观锁与悲观锁在MySQL中的应用

乐观锁与悲观锁在MySQL中的应用

时间:2024-08-07 10:49:19浏览次数:14  
标签:场景 版本号 乐观 并发 悲观 MySQL

本文由 ChatMoney团队出品

在数据库管理系统中,锁机制是保证数据一致性和并发控制的重要手段。MySQL,作为广泛使用的数据库系统之一,提供了多种锁策略来处理并发访问时可能引发的数据不一致性问题。其中,乐观锁和悲观锁是两种截然不同但又互补的并发控制策略,它们在不同的应用场景下发挥着各自的优势。本文将深入探讨MySQL中的乐观锁与悲观锁概念、工作原理及实际应用。

悲观锁

概念:

悲观锁,顾名思义,采取一种“预防性”的策略,假定每次数据操作都可能发生并发冲突,因此在数据被读取或修改前就将其锁定,确保同一时间只有一个事务能够访问该数据。这种锁机制适合于写操作远多于读操作或者并发写操作频繁的场景。

工作原理:

在MySQL中,悲观锁通常通过以下方式实现:

  • SELECT ... FOR UPDATE:在查询语句中加入FOR UPDATE子句,可以锁定查询结果集中的行,直到当前事务结束。

  • LOCK IN SHARE MODE:如果只需要读取数据但也要防止其他事务修改它,可以使用LOCK IN SHARE MODE,这会放置一个共享锁,允许其他事务读取但不能修改这些行。

SELECT * FROM products WHERE id = 1 FOR UPDATE;

优点:

  • 直接防止了并发修改,保证了数据的一致性。

  • 适用于写操作密集型的应用场景。

缺点:

  • 可能导致大量的锁竞争,从而影响系统的并发性能。

  • 长时间持有锁可能导致其他事务等待,甚至出现死锁。

乐观锁

概念:

与悲观锁相反,乐观锁假设数据一般不会发生并发冲突,只在提交更新操作时检查数据是否被其他事务修改过。如果数据未被修改,则更新成功;如果已被修改,则通常会重新读取数据再尝试更新,或者直接抛出错误。乐观锁适用于读多写少的场景,能够提供更高的并发性能。

工作原理:

在MySQL中,乐观锁常通过版本控制实现,如使用VERSION字段或时间戳字段:

  1. 添加版本字段:在表中增加一个版本号字段,每次数据被修改时,该版本号加一。

  2. 更新逻辑:在执行更新操作时,同时检查版本号,只有当版本号与事务开始时读取到的版本号相等时,才允许更新,否则拒绝更新或重试。

UPDATE products SET stock = stock - 1, version = version + 1 WHERE id = 1 AND version = expected_version;

优点:

  • 减少了锁的使用,提高了系统的并发性能。

  • 适用于读多写少的场景,减少了不必要的锁等待。

缺点:

  • 在高并发写入的场景下,由于频繁的重试,可能会降低效率。

  • 需要应用程序层面实现更多的逻辑来管理版本控制。

应用场景选择

选择使用乐观锁还是悲观锁,应根据具体的应用场景和业务需求来决定:

  • 当系统并发写操作较少,读操作占主导,并且对并发性能有较高要求时,乐观锁是更好的选择。

  • 对于写操作频繁,数据一致性要求极高的场景,悲观锁能够提供更直接、严格的数据保护,尽管可能牺牲一定的并发性能。

总之,乐观锁和悲观锁各有千秋,理解它们的工作原理和适用场景,能够帮助开发者更好地设计和优化数据库操作,确保数据的一致性和系统的高效运行。在实际开发中,合理结合这两种锁机制,可以更加灵活地应对各种并发控制挑战。

关于我们

本文由ChatMoney团队出品,ChatMoney专注于AI应用落地与变现,我们提供全套、持续更新的AI源码系统与可执行的变现方案,致力于帮助更多人利用AI来变现,欢迎进入ChatMoney获取更多AI变现方案!

标签:场景,版本号,乐观,并发,悲观,MySQL
From: https://www.cnblogs.com/chatlin/p/18346610

相关文章

  • 计算机毕业设计必看必学! ! 79197 基于ssm+mysql的学生心理健康在线咨询平台,原创定制
    摘要:在社会快速发展的影响下,教育业继续发展,大大增加了学生心理健康在线咨询平台的数量、多样性、质量等等的要求,使学生心理健康在线咨询平台的管理和运营比过去十年更加困难。依照这一现实为基础,设计一个快捷而又方便的学生心理健康在线咨询平台是一项十分重要并且有价值的事......
  • MySQL UDF 提权初探
    MySQLUDF提权初探对MySQLUDF提权做一次探究,什么情况下可以提权,提取的主机权限是否跟mysqld进程启动的主机账号有关数据库信息MySQL数据库版本:5.7.21UDFUDF:(UserDefinedFunction)用户自定义函数,MySQL数据库的初衷是用于方便用户进行自定义函数,方便查询一些复杂的数据......
  • MySQL安装
    目录前言MySQL5.7的安裝一、在线安装1.下载yumRepository2.安装yumRepository3.安装mysql5.7的服务4.开机自启动5.启动mysql6.查看状态7.获取临时密码8.登录mysql9.关闭密码复杂验证10.设置密码11.修改权限二、离线安装1、卸载已有的MySQL文件2、安装mysql......
  • 最全MySQL面试20题和答案(一)
    数据库基础知识为什么要使用数据库?数据保存在内存优点:存取速度快缺点:数据不能永久保存数据保存在文件优点:数据永久保存缺点:速度比内存操作慢,频繁的IO操作。查询数据不方便数据保存在数据库数据永久保存使用SQL语句,查询方便效率高。管理数据方便什......
  • 【MySQL】索引和事务
    秋招秋招中最经典,最高频的面试题文章目录索引index操作索引的SQL查看索引创建索引删除索引事务操作四个核心特性索引index在数据库中建立一个特殊的“目录“(一系列特定的数据结构),为了加快查询速度select查询都是遍历查询,比较复杂O(N)级别复杂度嵌......
  • Mysql事务四大特性的介绍
    1数据库事务        数据库的事务(Transaction)是一种机制、一个操作序列,包含了一组数据库操作命令。事务把所有的命令作为一个整体一起向系统提交或撤销操作请求,即这一组数据库命令要么都执行,要么都不执行,因此事务是一个不可分割的工作逻辑单元。在数据库系统上执行并......
  • MySQL中DayofWeek与Weekday的区别
    DAYOFWEEK(date):(1-7,周日始,美国人)这个函数返回日期date是一周中的哪一天,范围是1到7。其中,1表示周日,2表示周一,依此类推,7表示周六。这符合美国的日期习惯,即周日是一周的第一天。例如,DAYOFWEEK('2023-03-01')如果这一天是周三,将返回3。WEEKDAY(date):(0-6,周一始)WEEKDAY(......
  • 2024年8月6日(MySQL主从)
    一、glibc安装(回顾及补充)1、清空/etc/目录下的my.cnfls-l/etc/my.cnfrm-rf/etc/my.cnfyum-yremovemariadbfind/-name"*mysql*"-execrm-rf{}\;2、安装mysql软件包wgethttps://downloads.mysql.com/archives/get/p/23/file/mysql-8.0.33-linux-glibc2.......
  • 2024.8.06(mysql主从)
    一、glibc安装(回顾)mysql清空/etc/目录下的my.cnfls-l/etc/my.cnfrm-rf/etc/my.cnfyum-yremovemariadbfind/-name"*mysql*"-execrm-rf{}\;1、安装mysql软件包wgethttps://downloads.mysql.com/archives/get/p/23/file/mysql-8.0.33-linux-glibc2.12......
  • MySQL数据库基础1
    sql通用语法SQL语句可以单行或多行书写,以分号结尾。SQL语句可以使用空格/缩进来增强语句的可读性MySQL数据库的SQL语句不区分大小写,关键字建议使用大写注释:单行注释:--注释内容或#注释内容(MySQL特有)多行注释:/*注释内容*SQL分类DDL库操作查询所有数据库sho......