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失败,报错回滚或自旋。
当然,这里是为了模拟乐观锁的场景,实际上更新库存时一步便可以实现:
更新库存:
update t_goodsku set count=count -2 where id=#{id}; 到此,关于“mysql乐观锁如何实现”的学习就结束了,希望能够解决大家的疑惑。