Mysql中锁机制深入理解

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)

欢迎探讨!!

记录锁、间隙锁、临键锁小案例演示,你学废了吗

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值