乐观离线锁原理

实现方式:

通过在UPDATE/DELETE语句中增加版本号来实现锁机制。

 

解释:

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

 

场景(举例):

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

 

实现原理:

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

猜你喜欢

转载自ruby8.iteye.com/blog/1836910