返回顶部
首页 > 资讯 > 数据库 >MySQL中乐观锁扣减库存原理是什么
  • 720
分享到

MySQL中乐观锁扣减库存原理是什么

2023-07-06 02:07:44 720人浏览 独家记忆
摘要

这篇文章主要讲解了“MySQL中乐观锁扣减库存原理是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mysql中乐观锁扣减库存原理是什么”吧!1 基础知识在电商系统中扣减库存是一步非常关键

这篇文章主要讲解了“MySQL中乐观扣减库存原理是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mysql中乐观锁扣减库存原理是什么”吧!

    1 基础知识

    在电商系统中扣减库存是一步非常关键的操作,例如秒杀系统中一定要防止超卖情况出现,如果商家设置了100件库存但是最后卖出1000件,这样就会产生资金损失。在扣减库存时一般使用如下语句:

    udpate Goods set stock = stock - #{acquire} where sku_id = #{skuId} and stock - #{acquire} >= 0

    这条语句可以保护库存资源防止超卖,我们不妨分析这条语句为什么生效。本文使用mysql Innodb引擎进行演示,隔离级别为可重复读。

    1.1 共享锁与排它锁

    共享锁(share Lock)又被称为读锁,实现共享锁语句如下:

    select lock in share mode

    排它锁(exclusive Lock)又被称为写锁,实现排它锁语句如下:

    select for updateupdatedeleteinsert

    共享锁与排它锁兼容关系如下表:

    MySQL中乐观锁扣减库存原理是什么

    我们通过实例分析上述兼容关系,首先建一张测试表并写入测试数据:

    CREATE TABLE `test_account` (  `id` bigint(20) NOT NULL,  `name` varchar(20) DEFAULT NULL,  `account` bigint(20) DEFAULT NULL,  `version` bigint(20) DEFAULT NULL,  PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;insert  into `test_account`(`id`,`name`,`account`,`version`) values (1,'A',100,1);insert  into `test_account`(`id`,`name`,`account`,`version`) values (2,'B',200,1);insert  into `test_account`(`id`,`name`,`account`,`version`) values (3,'C',300,1);

    (1) 读读兼容

    共享锁与共享锁之间兼容,在如下实例中session1在t3时刻,session2在t4时刻执行查询均可以获取预期结果:

    MySQL中乐观锁扣减库存原理是什么

    (2) 读写互斥

    共享锁与排它锁之间互斥,在如下实例中session1在t3时刻加共享锁,可以正确读取结果,但是session2在t4时刻尝试加排它锁,但是此时锁被session1占有,session2需要等待,当session1长时间不释放锁时,session2抛出锁超时异常:

    MySQL中乐观锁扣减库存原理是什么

    (3) 写写互斥

    排它锁与排它锁之间互斥,在如下实例中session1在t3时刻加排它锁,可以正确读取结果,但是session2在t4时刻尝试加排它锁,但是此时锁被session1占有,session2需要等待,当session1长时间不释放锁时,session2抛出锁超时异常:

    MySQL中乐观锁扣减库存原理是什么

    1.2 当前读与快照读

    Mysql Innodb存储引擎实现基于多版本并发控制协议mvcC,在MVCC并发控制中读操作可以分成快照读与当前读。

    快照读不需要加锁,读取的是记录可见版本,有可能是历史版本。可以类比订单快照,用户下单之后商品价格发生了变化,但是订单快照不会改变。实现当前读语句如下:

    select

    当前读需要加锁,读取的是记录最新版本,加锁保证了在读取时,当前记录不会被其它事务修改。实现当前读语句如下:

    select lock in share modeselect for updateupdatedeleteinsert

    我们通过一个实例分析快照读和当前读,session2在t4时刻修改记录并在t5时刻提交,session1在t6时刻进行了快照读,读取的是本事务开始时结果100,在t7时刻进行了当前读,读取的是记录最新版本结果101:

    MySQL中乐观锁扣减库存原理是什么

    当前读流程是怎么样的呢?我们以update为例进行分析当前读流程:

    MySQL中乐观锁扣减库存原理是什么

    第一次程序实例发出当前读请求,存储引擎返回满足where条件的第一条记录并加锁,程序实例再发出更新请求,存储引起操作完成响应成功。依次执行直到所有满足where条件记录执行完成为止。

    这里我们做一些引申,RR级别提供了两种机制避免幻读问题:第一种方式是快照读,读取的是当前事务开启时的快照。第二种方式针对当前读,防止幻读依赖Next-Key Lock机制。

    2 乐观锁原理

    我们通过一个问题将上述知识整合起来:有两个线程在同一时刻执行如下语句,请问id=1这条记录account值会不会成功扣减两次?

    update test_account set account = account - 100, version = version + 1 where id = 1 and version = 1

    上述语句使用了乐观锁,我们知道乐观锁就是对资源进行保护的,所以答案是不会扣减两次,但是不能就此止步,需要结合第一章节知识进行进一步分析:

    MySQL中乐观锁扣减库存原理是什么

    t2时刻session1和session2同时执行update操作,由于update会加排它锁,所以两者只能有一个成功:session1成功,session2阻塞等待排它锁释放。

    t3时刻session1提交事务释放排它锁,此时session2获取到锁进行当前读,但是此时id=1记录version值已经变成了2,执行语句已经查询不到待更新数据,所以没有记录发生更新。

    3 扣减库存原理

    如果理解了第二章节乐观锁原理,那么扣减库存原理已经显而易见,我们假设商品只剩下1件库存,如果两个线程同时执行扣减库存,会发生超卖的情况吗?

    MySQL中乐观锁扣减库存原理是什么

    t2时刻session1和session2同时执行updatek扣减库存,由于update会加排它锁,所以两者只能有一个成功:session1成功,session2阻塞等待排它锁释放。

    t3时刻session1提交事务释放排它锁,此时session2获取到锁进行当前读,但是此时商品1库存已经变为0,已经不满足(where stock - 1 >= 0)条件,执行语句已经查询不到待更新数据,所以没有记录发生更新。

    感谢各位的阅读,以上就是“MySQL中乐观锁扣减库存原理是什么”的内容了,经过本文的学习后,相信大家对MySQL中乐观锁扣减库存原理是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

    您可能感兴趣的文档:

    --结束END--

    本文标题: MySQL中乐观锁扣减库存原理是什么

    本文链接: https://lsjlt.com/news/357372.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    猜你喜欢
    • MySQL中乐观锁扣减库存原理是什么
      这篇文章主要讲解了“MySQL中乐观锁扣减库存原理是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL中乐观锁扣减库存原理是什么”吧!1 基础知识在电商系统中扣减库存是一步非常关键...
      99+
      2023-07-06
    • 图解MySQL中乐观锁扣减库存原理
      目录1 基础知识1.1 共享锁与排它锁1.2 当前读与快照读2 乐观锁原理3 扣减库存原理1 基础知识 在电商系统中扣减库存是一步非常关键的操作,例如秒杀系统中一定要防止超卖情况出现,如果商家设置了100件库存但是最后卖...
      99+
      2023-04-13
      MySQL乐观锁扣减库存原理 MySQL乐观锁扣减库存 MySQL乐观锁
    • MySQL中乐观锁和悲观锁是什么
      这篇文章给大家分享的是有关MySQL中乐观锁和悲观锁是什么的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。数据库管理系统中并发控制的任务是确保在多个事务同时存取数据库中同一数据不破...
      99+
      2024-04-02
    • MYSQL中悲观锁和乐观锁的作用是什么
      这篇文章给大家介绍MYSQL中悲观锁和乐观锁的作用是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。  悲观锁(Pessimistic Lock)  悲观锁(Pessimistic ...
      99+
      2024-04-02
    • mysql中乐观锁和悲观锁有什么区别
      mysql中乐观锁和悲观锁的区别有:1.概念不同;2.使用场景不同;3.实现方式不同;4.特点不同;mysql中乐观锁和悲观锁的区别有以下几点概念不同mysql中乐观锁是对加锁持有一种乐观的态度,可以先进行业务操作,不到最后一步不进行加锁,...
      99+
      2024-04-02
    • 【MySQl】MySQl中的乐观锁是怎么实现的
      文章目录 前言一、乐观锁二、如何实现乐观锁呢,一般来说有以下2种方式2.1、使用数据版本(Version)记录机制实现2.2、乐观锁定的第二种实现方式和第一种差不多 前言 mysql中...
      99+
      2023-09-20
      mysql oracle 数据库
    • mysql中的乐观锁是怎么实现的
      mysql中的乐观锁是怎么实现的?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。乐观锁( Optimistic Locking ...
      99+
      2024-04-02
    • MySQL数据库缓存原理是什么
      今天就跟大家聊聊有关MySQL数据库缓存原理是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。  MySQL数据库查询步骤有哪些  当MySQL收...
      99+
      2024-04-02
    • MySQL锁机制原理是什么
      这篇文章主要介绍“MySQL锁机制原理是什么”,在日常操作中,相信很多人在MySQL锁机制原理是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL锁机制原理是什么”...
      99+
      2024-04-02
    • MySQL锁类型和加锁原理是什么
      这篇文章主要介绍了MySQL锁类型和加锁原理是什么,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。首先对mysql锁进行划分:按照锁的粒度划分:行...
      99+
      2024-04-02
    • MySQL中锁机制的底层原理是什么
      本篇文章给大家分享的是有关MySQL中锁机制的底层原理是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、Mysql为什么要加锁锁机制用于...
      99+
      2024-04-02
    • MySQL锁定机制的原理是什么
      这篇文章给大家介绍MySQL锁定机制的原理是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。  数据库锁定机制简单来说,就是数据库为了保证数据的一致性,而使各种共享资源在被并发访问变...
      99+
      2024-04-02
    • mysql中查询缓存的原理是什么
      mysql中查询缓存的原理是什么?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1、说明MYSQL的查询缓存本质上是缓存SQL的hash值和该SQL的查询结果,如果运行相同的...
      99+
      2023-06-15
    • mysql行级锁的实现原理是什么
      MySQL行级锁的实现原理是通过两种方式来实现的:锁的粒度和锁的类型。 锁的粒度: MySQL的行级锁是在InnoDB存储引擎中...
      99+
      2024-04-09
      mysql
    • 数据库中的索引和锁底层原理是什么
      数据库中的索引和锁底层原理是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。 一、索引在之前,我对索引有以下的认知...
      99+
      2024-04-02
    • java中自旋锁的原理是什么
      本篇文章给大家分享的是有关java中自旋锁的原理是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Java可以用来干什么Java主要应用于:1. web开发;2. Andro...
      99+
      2023-06-14
    • Android中实现观察者模式的原理是什么
      这篇文章将为大家详细讲解有关Android中实现观察者模式的原理是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。观察者模式:A类中定义一个被观察者画家package com.exampl...
      99+
      2023-05-31
      android 观察 观察者模式
    • python 中GIL锁的底层原理是什么
      这篇文章将为大家详细讲解有关python 中GIL锁的底层原理是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。python可以做什么Python是一种编程语言,内置了许多有效的工具,Py...
      99+
      2023-06-14
    • Mysql数据库group by原理是什么
      这篇文章主要介绍“Mysql数据库group by原理是什么”,在日常操作中,相信很多人在Mysql数据库group by原理是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Mysql...
      99+
      2023-07-02
    • mysql数据库底层原理是什么
      这篇“mysql数据库底层原理是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“mysq...
      99+
      2023-04-22
      mysql
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作