您现在的位置是:群英 > 数据库 > MySQL数据库
MySQL乐观锁的实现方法和步骤是什么
Admin发表于 2022-05-12 16:35:481512 次浏览
这篇文章给大家介绍了“MySQL乐观锁的实现方法和步骤是什么”的相关知识,讲解详细,步骤过程清晰,对大家进一步学习和理解“MySQL乐观锁的实现方法和步骤是什么”有一定的帮助,希望大家阅读完这篇文章能有所收获。下面就请大家跟着小编的思路一起来学习一下吧。

在mysql中,可以利用数据版本Version记录机制实现乐观锁,给数据表加一个version字段,每操作一次记录的版本号加一,判断version的值是否与刚查询的值相等,若相等则执行更新,若不相等则不进行更新。

本教程操作环境:windows10系统、mysql8.0.22版本、Dell G3电脑。

mysql乐观锁怎么实现

实现方法

1、用数据版本Version记录机制实现,这是乐观锁最常用的一种实现方式。

2、数据版本,即为数据增加一个版本标识,一般是通过为数据库表增加一个数字类型的 version字段来实现。当读取数据时,将version字段的值一同读出,数据每更新一次,对此version值加1。当我们提交更新的时候,判断数据库表对应记录的当前版本信息与第一次取出来的version值进行比对,如果数据库表当前版本号与第一次取出来的version值相等,则予以更新,否则认为是过期数据。

实例

update TABLE
set value=2,version=version+1
where id=#{id} and version=#{version}

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

乐观锁是指操作数据库时(更新操作),想法很乐观,认为这次的操作不会导致冲突,在操作数据时,并不进行任何其他的特殊处理(也就是不加锁),而在进行更新后,再去判断是否有冲突了。整体思想就是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-commited和read-repeatable隔离机制下的MVCC机制),在这种情况下,第3步去update时,获取锁,where条件中进行判断中的version=#{version},其实是拿当前version和第1步中的快照version进行比对

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

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

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

1、更新库存:

update t_goodsku
set count=count -2
where id=#{id};

通过以上内容的阐述,相信大家对“MySQL乐观锁的实现方法和步骤是什么”已经有了进一步的了解,更多相关的问题,欢迎关注群英网络或到群英官网咨询客服。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

标签: mysql乐观锁
相关信息推荐
2022-05-11 15:28:53 
摘要:本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了对常见的死锁案例进行相关分析与探讨,以及如何去尽可能避免死锁给出一些建议,希望对大家有帮助。
2022-08-03 17:46:04 
摘要:oracle释放删除表空间的方法:1、利用“alter table 你的表名 enable row movement;”语句开启允许行移动,该语句允许rowid改变;2、利用“alter table 你的表名 shrink space;”语句回收空间即可。
2022-10-19 18:00:28 
摘要:本篇文章给大家带来了关于MySQL的相关知识,其中主要整理了占用内存过大解决方法的相关问题,分别使用windows和CentOS7两种系统来解决该问题,下面一起来看一下,希望对大家有帮助。
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部