首页 » PHP教程 » mysql乐不雅锁PHP技巧_卓象科技MYSQL的消极锁和乐不雅观锁

mysql乐不雅锁PHP技巧_卓象科技MYSQL的消极锁和乐不雅观锁

访客 2024-11-03 0

扫一扫用手机浏览

文章目录 [+]
小编

悲观锁(Pessimistic Lock)

悲观锁(Pessimistic Lock), 顾名思义,便是很悲观,每次去拿数据的时候都认为别人会修正,以是每次在拿数据的时候都会上锁,这样别人想拿这个数据就会block直到它拿到锁。
传统的关系型数据库里边就用到了很多这种锁机制,比如行锁,表锁等,读锁,写锁等,都是在做操作之前先上锁。

mysql乐不雅锁PHP技巧_卓象科技MYSQL的消极锁和乐不雅观锁

最常用的便是 select … for update,它是一种行锁,会把select出来的结果行锁住,在本事务提交或者回滚之前,不许可其他事务对这些行做update、delete、for update操作。

mysql乐不雅锁PHP技巧_卓象科技MYSQL的消极锁和乐不雅观锁
(图片来自网络侵删)

乐不雅观锁(Optimistic Lock)

乐不雅观锁(Optimistic Lock), 顾名思义,便是很乐不雅观,每次去拿数据的时候都认为别人不会修正,以是不会上锁,期间该数据可以随便被其他人读取,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,可以利用版本号等机制。

版本号机制是乐不雅观锁最常用的办法,便是在表中增加一个版本号的字段,更新前先查一遍获取版本号,再作为更新语句的where条件进行更新,如果数据在获取版本号之后,在更新之前已经改变了,那就会更新失落败,由于末了更新了0条数据,PHP后台拿到更新数如果为0,则解释更新失落败,涌现了并发问题,然后做详细的处理。

例如有两个人同时对某条数据做修正,过程如下:

操作员A操作如下:

select id, balance, version from table where id=“1”;

查询结果:id=1, balance=1000, version=1

update table set balance=balance+100, version=version+1 where id=“1” and version=1;

实行后,返回的更新结果是1,解释更新了一条,数据库里的结果是:id=1, balance=1100, version=2

操作员B操作如下:

select id, balance, version from table where id=“1”;

查询结果:id=1, balance=1000, version=1, 解释操作员A还没修正。

update table set balance=balance-50, version=version+1 where id=“1” and version=1 ;

查的时候,操作员A还没修正,当要更新时,操作员A已经先修正成功,以是数据库里实际值是id=1, balance=1100, version=2,

操作员B也将版本号加一(version=2)试图向数据库提交数据(balance=950),但此时查不到where id=“1” and version=1 的数据,

以是update就失落败了,实行结果是0,解释没有对任何数据更新成功。

现在再去查一下,结果还是操作员A操作完成之后的结果

select id, balance, version from table where id=“1”;

查询结果:id=1, balance=1100, version=2

以上是自己实现版本号机制的事理,真正利用的版本号机制是数据库本身带有的机制,一旦创造更新的版本号不是最新的就会被驳回

标签:

相关文章

介绍白点控制之路,从原理到方法

白点,作为生活中常见的现象,无处不在。对于如何控制白点,许多人却感到困惑。本文将从原理出发,探讨白点的控制方法,并结合实际案例,为...

PHP教程 2025-01-03 阅读1 评论0

介绍直播王者,如何开启你的电竞直播之旅

随着电竞产业的蓬勃发展,越来越多的年轻人投身于电竞直播行业。王者荣耀作为一款备受欢迎的MOBA手游,吸引了大量玩家和观众。如何开启...

PHP教程 2025-01-03 阅读1 评论0