当前位置:Gxlcms > 数据库问题 > MySQL乐观锁

MySQL乐观锁

时间:2021-07-01 10:21:17 帮助过:15人阅读

  乐观锁,是说在数据进行提交更新的时候,会对数据的冲突与否进行检测,如果发生冲突了,则返回错误的信息,让用户决定如何去做。

  乐观锁的实现一般是在程序中来控制的。常规的实现一般有两种:使用数据版本(version),使用时间戳来实现。

实现详情:

1. 在表里添加一个字段version或者时间戳字段;

2. 在查询的时候,将该字段返回,更新的时候,先校验version字段或时间戳字段是否和表里的字段一致,如果一致就更新,并且把version字段加1(时间戳的话更新为当前时间),如果不一致就说明该字段已经被更新过,提示更新失败,然后把错误信息返回给用户;

 通过一些伪代码来实现:

-- 伪代码:
-- 1. 并发查询,都查询id=1的记录
mysql> SELECT * FROM test_order WHERE id = 1;
+----+--------+------+----------+---------+-------------+
| id | status | name | goods_id | version | update_date |
+----+--------+------+----------+---------+-------------+
|  1 |      1 | 茅台 | 123      |       1 | NULL        |
+----+--------+------+----------+---------+-------------+
1 row in set

-- 2. 用户1执行更新操作
UPDATE test_order 
SET status=1, version=version+1 
WHERE id=1 and version=1 

-- 3. 此时version是2,用户2再次执行更新操作,但此时就更新不成功了
UPDATE test_order 
SET status=1, version=version+1 
WHERE id=1 and version=1

 

常用的SVN便是通过这种类似的方式来实现的。

MySQL乐观锁

标签:查询   更新   时间戳   bsp   说明   null   sql   name   from   

人气教程排行