悲观锁
查出来的数据必须是根据索引查出来的,不然锁表。
# 语法
select * from table where id = 1 for update;
乐观锁
使用一个标识 cas 比较后替换
如果每次访问冲突概率小于 20%,推荐使用乐观锁,否则使用悲观锁。乐观锁的重试次 数不得小于 3 次。
select version from table;
# update 返回有影响行数表示成功,没有失败
update set name = "新名字" , version += 1
where id = 1 and version = 上面查出来的version