乐观离线锁

乐观离线锁最常见的实现方式是通过在UPDATE/DELETE语句中增加版本号来实现锁机制。

之所以叫离线锁是因为这种锁不是长时间的锁,而且一个业务事务中可能同时包含了几个系统事务。而乐观是相对悲观而言的,表示预计冲突不总是发生,以其得到最大的性能。

可能对业务事务,系统事务的概念大家有些陌生。按我的理解,可以这样解释:首先,你要明白事务不仅仅是一个技术问题(系统事务),更是一个领域问题(业务事务),举例说明,我们编辑一篇文章,显示编辑页面的动作可能涉及一个系统事务,提交表单的时候又涉及了一个系统事务,而整体可以看成一个业务事务。

如果不使用锁,那么就会产生不一致问题,如两个人一起编辑同一个文章,后一个提交的人就会覆盖前一个人的修改。

使用悲观离线锁似乎不错,我们可以在表里加一个字段表示当前记录是否被锁定,当显示编辑界面的时候就立刻设定为锁定,阻止其他人编辑,然后当提交的时候再解锁,看上去很美,但这个方法有很多问题,比如:打开编辑界面,记录标记为锁定,然后因为某些原因关闭了浏览器,问题出现了,记录将一直处于锁定状态。

使用乐观离线锁可以解决这个问题,通过在文章表里加入一个version字段,编辑之初从数据库中取出此值,保存在session中,编辑结束后UPDATE version = version + 1, ... WHERE version = ...来确保一致性,如果之前已经有人提交了,则version已经加一,那么再使用session里的version值进行比较,WHERE version = ... 将不再成立,影响行数为0,数据库回滚。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lxr1908

用钱砸我

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值