mysql乐观锁如何实现


这篇文章主要介绍“mysql乐观锁如何实现”,在日常操作中,相信很多人在mysql乐观锁如何实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysql乐观锁如何实现”的疑惑有所帮助!接下来,请跟着小编一起来学习吧! 在mysql中,可以利用数据版本Version记录机制实现乐观锁,给数据表加一个version字段,每操作一次记录的版本号加一,判断version的值是否与刚查询的值相等,若相等则执行更新,若不相等则不进行更新。本教程操作环境:windows10系统、mysql8.0.22版本、Dell G3电脑。实现方法1、用数据版本Version记录机制实现,这是乐观锁最常用的一种实现方式。2、数据版本,即为数据增加一个版本标识,一般是通过为数据库表增加一个数字类型的 version字段来实现。当读取数据时,将version字段的值一同读出,数据每更新一次,对此version值加1。当我们提交更新的时候,判断数据库表对应记录的当前版本信息与第一次取出来的version值进行比对,如果数据库表当前版本号与第一次取出来的version值相等,则予以更新,否则认为是过期数据。实例乐观锁不是数据库自带的,需要我们自己去实现。乐观锁是指操作数据库时(更新操作),想法很乐观,认为这次的操作不会导致冲突,在操作数据时,并不进行任何其他的特殊处理(也就是不加锁),而在进行更新后,再去判断是否有冲突了。整体思想就是CAS思想。通常实现是这样的:在表中的数据进行操作时(更新),先给数据表加一个版本(version)字段,每操作一次,将那条记录的版本号加1。也就是先查询出那条记录,获取出version字段,如果要对那条记录进行操作(更新),则先判断此刻version的值是否与刚刚查询出来时的version的值相等,如果相等,则说明这段期间,没有其他程序对其进行操作,则可以执行更新,将version字段的值加1;如果更新时发现此刻的version值与刚刚获取出来的version的值不相等,则说明这段期间已经有其他程序对其进行操作了,则不进行更新操作。eg:下单操作包括3步骤:1、查询出库存信息:2、扣减2个库存:程序中计算:count = count – 2;3开发云主机域名、更新库存:第1步中查到的version其实是快照(read-commited和read-repeatable隔离机制下的MVCC机制),在这种情况下,第3步去update时,获取锁,where条件中进行判断中的version=#{version},其实是拿当前version和第1步中的快照version进行比对如果比对成功,说明在这段时间内这条数据没有被其他线程更新过,update成功;如果对比失败,说明这段时间内这条数据被更新过,那么update失败,报错回滚或自旋。当然,这里是为了模拟乐观锁的场景,实际上更新库存时一步便可以实现:更新库存:到此,关于“mysql乐观锁如何实现”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注开发云网站,小编会继续努力为大家带来更多实用的文章!

相关推荐: SQL创建表外键约束的语句怎么写

这篇文章主要介绍SQL创建表外键约束的语句怎么写,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!SQL外键约束可通过FOREIGN KEY关键字来指定,创建语句为“ALTER TABLE 表名 ADD CONSTRAINT 外键名 FOR…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 06/28 20:41
下一篇 06/28 20:41

相关推荐