mysql乐观锁的实现_如何实现乐观锁

mysql乐观锁的实现_如何实现乐观锁使用Mysql实现分布式锁

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

乐观锁不是数据库自带的,需要我们自己去实现

乐观锁是指操作数据库时(更新操作),想法很乐观,认为这次的操作不会导致冲突,在操作数据时,并不进行任何其他的特殊处理(也就是不加锁),而在进行更新后,再去判断是否有冲突了。整体思想就是CAS思想。

通常实现是这样的:在表中的数据进行操作时(更新),先给数据表加一个版本(version)字段,每操作一次,将那条记录的版本号加1。也就是先查询出那条记录,获取出version字段,如果要对那条记录进行操作(更新),则先判断此刻version的值是否与刚刚查询出来时的version的值相等,如果相等,则说明这段期间,没有其他程序对其进行操作,则可以执行更新,将version字段的值加1;如果更新时发现此刻的version值与刚刚获取出来的version的值不相等,则说明这段期间已经有其他程序对其进行操作了,则不进行更新操作。

eg:

下单操作包括3步骤:

1、查询出库存信息

select (id,count,version) from t_goodsku where id=#{id}

2、扣减2个库存:

程序中计算:count = count – 2;

3、更新库存:

update t_goodsku

set count={count},version=version+1

where id=#{id} and version=#{
version};

 

1步中查到的version其实是快照(read-commitedread-repeatable隔离机制下的MVCC机制),在这种情况下,第3步去update时,获取锁,where条件中进行判断中的version=#{version},其实是拿当前version和第1步中的快照version进行比对

如果比对成功,说明在这段时间内这条数据没有被其他线程更新过,update成功;

如果对比失败,说明这段时间内这条数据被更新过,那么update失败,报错回滚或自旋。

当然,这里是为了模拟乐观锁的场景,实际上更新库存时一步便可以实现:

1、更新库存:

update t_goodsku

set count=count -2

where id=#{id};

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/179602.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • thinkphp发送邮件需要开启什么设置

    thinkphp发送邮件需要开启什么设置

    2021年9月21日
    48
  • 隐马尔可夫模型_基于hmm模型外汇预测

    隐马尔可夫模型_基于hmm模型外汇预测隐马尔科夫模型,HiddenMarcovModel,是可用于标注问题的统计学习模型,描述由隐藏的马尔科夫链随机生成观测序列的过程,属于生成模型,是一种比较重要的机器学习方法,在语音识别等领域有重要的应用。 本文不打算使用书面的一大堆公式来说明,本人对公式无感,能用例子说明的根本不想碰公式,不知道是不是霍金说过,多加一条公式就会损失一大片读者。PS:不管有没有说过了,是这个意思,what

    2022年9月30日
    2
  • 复变函数与积分变换系列(二) – 复变函数的求导

    复变函数与积分变换系列(二) – 复变函数的求导复变函数的求导 Author Benjamin TOC 1 复变函数求导 1 1 函数在某点可导 可微 的充要条件 uuu 在该点连续 vvv 在该点连续满足 Cauchy Reimann 方程 KaTeXparseer Expected got part atposition7 frac p a r t u p

    2025年7月10日
    4
  • 阿里p7架构师力荐《Android性能优化—实战解析》,全方面解析Android性能优化

    阿里p7架构师力荐《Android性能优化—实战解析》,全方面解析Android性能优化前言 Android 已经融入了寻常百姓的生活中 当今世界 手机正从功能时代进化到智能时代 同时又诞生了令人爱不释手的平板电脑 目前 应用程序开发者的可选择平台主要就是 Android 和 iOSAndroid 降低了甚至可以说是打破了移动开发的门槛 应用程序开发者编写 Android 应用程序只需要一台计算机就够了 当然还要有一些编程知识 工具都是免费的 几乎每个人都能写出数百万人会用的应用 Android 可以运行在各种设备上 从平板到电视 开发者关键要做的就是保证应用可以顺利地在这些设备上运行 而且比竞争对手的

    2025年11月12日
    3
  • python与c语言的区别与联系_爬虫python和c语言区别

    python与c语言的区别与联系_爬虫python和c语言区别经过不算是长时间的学习,相比我之前学的C语言,我觉得Python,有以下特点:1.因为C语言是编译型语言,python是解释型语言,所以python的执行速度没有C语言那么快。2.基本元素的区别,python中的基本元素相比于C语言大大减少,比较特殊的就是python语言中的tuple(元组),一个类似于列表且内部元素不允许被改变的一个数据,这样可以使得程序的数据更加安全;其次是python中…

    2025年8月2日
    5
  • 从源码的角度深入理解spring AOP原理及流程

    从源码的角度深入理解spring AOP原理及流程

    2021年8月3日
    59

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号