Mysql中锁机制深入理解
默认大家已经知道。
分类
性能
悲观锁,乐观锁
操作类型
读锁,写锁,
数据粒度
表锁,行锁,页面锁
更细粒度
间隙锁,临键锁
按使用来讲。
由数据粒度出发。
表锁,分为
共享锁,Table Shared Lock;
表独占锁,Table Write Lock;
页面锁,分为
共享锁,Shared Lock;
独占锁,Exclusive Lock;
行锁,分为
共享锁,Shared Lock;
排他锁,Exclusive Lock;
不管怎么样。
都可以分为
共享锁(读锁),大家可以一起读取,但是不能update之类的,可以叫海王。
独占锁(排他),只能我一个人拥有和改变,叫一个人的深情。
下面就是重点了
间隙锁和临键锁(next-key锁)
在我看来,行锁,其实是包括间隙锁和临键锁的。
刚百度了,
其中行锁分为:(行锁)记录锁、间隙锁、next-key锁(行锁+间隙锁)、插入意向锁、隐式锁。
间隙分为区间。
id:
1,2,3,6,7,8,18;
那么区间为,
(3,6), (8,18), (18,+无穷)
有东西出现在这三个空记录区间,就会产生 间隙锁。
详细说明
假设查询id为,[2,9]的记录。
select*fromuserwhere id>=2and id<=9
情况如下,
2,3 - 有记录,记录锁(普通行锁)。
(3-6) - 区间没有记录,间隙锁。
6,7,8 -有记录,记录锁(普通行锁)。
(8,18) -区间没有记录,间隙锁。
所以以上,全部加起来。
间隙锁,是闭区间。左毕右毕,我爬起来本地实验了。
[2,18),就是 行锁+间隙锁=临键锁(next-key)
欢迎探讨!!
记录锁、间隙锁、临键锁小案例演示,你学废了吗