精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

記錄鎖、間隙鎖與 Next-Key Lock

數據庫 MySQL
現在 Gap Lock 間隙鎖,就是要把這些記錄之間的間隙也給鎖住,間隙鎖住了,就不用擔心幻讀問題了,這也是 Gap Lock 存在的意義。

有小伙伴在微信上表示面試時被問到了 Next-Key Lock 是啥,結果一臉懵逼,那么今天我們來捋一捋 MySQL 中的記錄鎖、間隙鎖以及 Next-Key Lock。

1. Record LockRecord

Lock 也就是我們所說的記錄鎖,記錄鎖是對索引記錄的鎖,注意,它是針對索引記錄,即它只鎖定記錄這一行數據。

例如如下一條 SQL:

select * from user where id=1 for update;

注意,id 是索引,id 如果不是索引,上面這條 SQL 所加的排他鎖就不是一個 Record Lock。

我們來看如下一個例子:

首先我們將系統變量 innodb_status_output_locks 設置為 ON,如下:

接下來我們執行如下 SQL,鎖定一行數據,此時會自動為表加上 IX 鎖:

接下來我們在一個新的會話中執行如下指令來查看 InnoDB 存儲引擎的情況:

show engine innodb status\G

輸出的信息很多,我們重點關注 TRANSACTIONS,如下:

可以看到:

  • TABLE LOCK table test08.user trx id 3564804 lock mode IX:這句就是說事務 id 為 3564804 的事務,為 user 表添加了意向排他鎖(IX)。
  • RECORD LOCKS space id 851 page no 3 n bits 80 index PRIMARY of table test08.user trx id 3564804 lock_mode X locks rec but not gap:這個就是一個鎖結構的記錄,這里的索引是 PRIMARY,加的鎖也是正兒八經的記錄鎖(not gap)。

看到了 LOCKS REC BUT NOT GAP,就說明這是一個記錄鎖。

那么這個 Record Lock 和我們之前所講的 S 鎖以及 X 鎖有什么區別呢?S 鎖是共享鎖,X 鎖是排他鎖,當我們加 S 鎖或者 X 鎖的時候,如果用到了索引,鎖加在了某一條具體的記錄上,那么這個鎖也是一個記錄鎖(其實,記錄鎖,S 鎖,X 鎖,概念有一些重復的地方,但是描述的重點不一樣)。

或者也可以理解為記錄鎖又細分為 S 鎖和 X 鎖,它們之間的兼容性如下圖:

兼容性

S 型記錄鎖

X 型記錄鎖

S 型記錄鎖

兼容

不兼容

X 型記錄鎖

不兼容

不兼容

2. Gap Lock

Gap Lock 也叫做間隙鎖,它的存在可以解決幻讀問題,另外需要注意,Gap Lock 也只在 REPEATABLE READ 隔離級別下有效。先來看看什么是幻讀,我們來看如下一個表格:

有兩個會話,A 和 B,先在會話 A 中開啟事務,然后查詢 age 為 99 的用戶總數,注意使用當前讀,因為在默認的隔離級別下,默認的快照讀并不能讀到其他事務提交的數據,至于快照讀和當前讀的區別,大家參考:S 鎖與 X 鎖,當前讀與快照讀!。當會話 A 中第一次查詢過后,會話 B 中向數據庫添加了一行記錄,等到會話 A 中第二次查詢的時候,就查到了和第一次查詢不一樣的結果,這就是幻讀(注意幻讀專指數據插入引起的不一致)。

在 MySQL 默認的隔離級別 REPEATABLE READ 下,上圖所描述的情況無法復現。無法復現的原因在于,在 MySQL 的 REPEATABLE READ 隔離級別中,它已經幫我們解決了幻讀問題,解決的方案就是 Gap Lock。

大家想想,之所以出現幻讀的問題,是因為記錄之間存在縫隙,用戶可以往這些縫隙中插入數據,這就導致了幻讀問題,如下圖:

如圖所示,id 之間有縫隙,有縫隙就有漏洞。前面我們所說的記錄鎖只能鎖住一條具體的記錄,但是對于記錄之間的空隙卻無能無力,這就導致了幻讀(其他事務可往縫隙中插入數據)。

現在 Gap Lock 間隙鎖,就是要把這些記錄之間的間隙也給鎖住,間隙鎖住了,就不用擔心幻讀問題了,這也是 Gap Lock 存在的意義。

給一條記錄加 Gap Lock,是鎖住了這條記錄前面的空隙,例如給 id 為 1 的記錄加 Gap Lock,鎖住的范圍是 (-∞,1),給 id 為 3 的記錄加 Gap Lock,鎖住的范圍是 (1,3),那么 id 為 10 后面的空隙怎么鎖定呢?MySQL 提供了一個 Supremum 表示當前頁面中的最大記錄,所以最后針對 Supremum 鎖住的范圍就是 (10,+∞),這樣,所有的間隙都被覆蓋到了,由于鎖定的是間隙,所以都是開區間。

那么我們怎么樣能看到 Gap Lock 呢?我給大家舉一個簡單的例子,假設我有如下一張表:

CREATE TABLE `user` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`username` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`age` int(11) DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `age` (`age`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

一個簡單的表,id 是主鍵,age 是普通索引,表中有如下幾條記錄:

接下來我們執行如下 SQL,鎖定一行數據,此時也會產生間隙鎖:

接下來我們在一個新的會話中執行如下指令來查看 InnoDB 存儲引擎的情況:

show engine innodb status\G

輸出的信息很多,我們重點關注 TRANSACTIONS,如下:

紅色框選中的,就是一個間隙鎖的加鎖記錄,可以看到,在某一個記錄之前加了間隙鎖。

這就是間隙鎖。非常重要的一點需要大家牢記:Gap Lock 只在 REPEATABLE READ 隔離級別下有效。

3. Next-Key Lock

以下內容都是基于 MySQL 默認的隔離級別 REPEATABLE READ。

如果我們既想鎖定一行,又想鎖定行之間的記錄,那么就是 Next-Key Lock 了,換言之,Next-Key Lock 是 Record Lock 和 Gap Lock 的結合體。

正常來說,我們加行鎖的基本單位就是 Next-Key Lock,即既有記錄鎖又有間隙鎖,但是有時候 Next-Key Lock 會退化,我們通過幾個簡單的例子來分析一下。

首先我們來看看 Next-Key Lock 的加鎖規則:

  • 鎖的范圍是左開右閉。
  • 如果是唯一非空索引的等值查詢,Next-Key Lock 會退化成 Record Lock。
  • 普通索引上的等值查詢,向后遍歷時,最后一個不滿足等值條件的時候,Next-Key Lock 會退化成 Gap Lock。

我們通過幾個簡單的例子來分析下。

3.1 唯一非空索引

假設我有一個學生表,學生表中有學生的姓名和成績,如下:

CREATE TABLE `student` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`score` double NOT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `score` (`score`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

id 是主鍵,score 是成績,其中 score 是唯一非空索引。

現在表中有如下數據:

假設我們執行如下 SQL:

在這個例子中,由于 score 是唯一非空索引,所以 Next-Key Lock 會退化成 Record Lock,換句話說,這行 SQL 只給 score 為 90 的記錄加鎖,不存在 Gap Lock,即我們新開一個會話,插入一條 score 為 88 的記錄也是 OK 的。

不過這里有一個特例,如果鎖定的是一個不存在的記錄,那么也會產生間隙鎖,例如下面這個:

由于并不存在 score 為 91 的記錄,所以這里會產生一個范圍為 (90,95) 的間隙鎖,我們執行如下 SQL 可以驗證:

可以看到,90.1、94.9 都會被阻塞(我按了 Ctrl C,所以大家看到查詢終止)。

90、95 則不符合唯一非空索引的條件。

95.1 則可以插入成功。

沒問題。

3.2 非空索引

現在我們重新開始,將 score 索引改為普通索引,如下:

CREATE TABLE `student` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`score` double NOT NULL,
PRIMARY KEY (`id`),
KEY `score` (`score`)
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

數據還是跟前面一樣,此時我們來執行如下 SQL:

我們來分析下。

此時要鎖定的是 id 為 90 的記錄,那么首先加間隙鎖,上一個 score 為 89,所以這次加的間隙鎖范圍是 (89,90),同時要鎖定 id 為 90 的記錄,所以進一步優化為 (89,90]。

同時,這里還有一條規則,就是滿足條件的上一條記錄,也需要被鎖住,所以最終的鎖范圍就是 [89,90]。

由于 score 不是唯一性索引,所以還需要繼續向后查找,找到的下一條記錄是 95,由于此時 Next-Key Lock 會退化成 Gap Lock,所以鎖定的范圍是 (90,95)。綜上,最終鎖定的范圍是 [89,95)。

接下來我們可以新開一個會話,我們分別嘗試添加如下數據看看是否能夠添加成功:

可以看到,score 為 88 是可以的,但是為 89.1 就不行。

score 為 95 也是可以的,但是為 94.9 就不行。

再試一下 89 是否可以:

說明我們上面分析的加鎖范圍是正確的。

再來看如下一條 SQL:

跟前面的案例相比,這次多了 limit 1,limit 1 表示只要一條記錄,所以這次查找到 90 之后就不會再往后查找了,那么最終的鎖就是間隙鎖+一個記錄鎖,最終的范圍就是 [89,90]。

此時新開一個會話,分別插入 score 為 88.9、89、90、91 的 記錄,驗證我們上面所分析的加鎖范圍:

88.9 和 89 的插入結果跟我們預想的一致。

可以看到,這里 90 也能插入,能插入的原因是因為缺乏 90 往后的間隙鎖。

4. 小結

MySQL 中的鎖有點繁雜,小伙伴們可以趁著某個周末,花點時間捋一捋,以后面試再遇到這些問題的時候就不頭大了。

責任編輯:武曉燕 來源: 江南一點雨
相關推薦

2025-04-24 10:56:01

MySQLInnoDB數據庫鎖

2024-06-12 14:03:31

MySQLInnoDB

2021-06-08 09:41:26

MySQL加鎖范圍

2021-06-05 18:02:20

MySQL加鎖范圍

2025-06-04 02:55:00

MySQL意向鎖記錄鎖

2023-06-05 08:15:30

MySQLInnoDB

2022-10-24 08:02:14

MySQL索引類型

2025-08-15 07:55:20

2023-11-06 08:35:08

表鎖行鎖間隙鎖

2023-12-06 07:33:20

MySQL鎖事間隙鎖

2020-10-20 13:50:47

MySQL數據庫

2025-11-14 00:00:15

2025-11-10 08:41:06

2021-12-14 08:10:00

MySQL行鎖間隙鎖

2024-01-16 12:19:08

MySQL重要機制高并發

2020-07-02 08:22:56

MySQL間隙鎖過行鎖

2025-09-16 07:09:32

2024-05-17 09:33:22

樂觀鎖CASversion

2011-11-28 12:55:37

JavaJVM

2013-12-19 13:25:40

InnoDB數據庫
點贊
收藏

51CTO技術棧公眾號

激情视频一区| 玖玖精品一区| 国产日本欧洲亚洲| 国产精品自拍视频| 青青草激情视频| 精品欧美午夜寂寞影院| 欧美伊人精品成人久久综合97 | 成人av地址| 色综合久久久久综合体| 小说区视频区图片区| 欧美特级特黄aaaaaa在线看| 久久亚洲精选| 欧美超级乱淫片喷水| 国产精品300页| 亚洲精品66| 欧美日韩人人澡狠狠躁视频| 亚洲精品第一区二区三区| 亚洲成人中文字幕在线| 石原莉奈在线亚洲二区| 欧美高清激情视频| 亚洲自拍偷拍图| 国产精品香蕉| 欧美福利视频一区| 国产日韩一区二区在线观看| www视频在线看| 久久久久久久综合狠狠综合| 成人欧美一区二区三区视频xxx| 日韩精选在线观看| 亚洲激情在线| 欧美成人免费小视频| 亚洲精品91在线| 欧美大片网址| 日韩一区二区三区视频| 一区二区三区韩国| 中文字幕在线免费观看视频| 一区二区三区久久久| 亚洲欧美日韩不卡一区二区三区| 五月婷婷在线观看视频| 国产·精品毛片| 亚洲va久久久噜噜噜| 一区二区自拍偷拍| 久久一区视频| 2018国产精品视频| 久久综合加勒比| 91精品国产福利在线观看麻豆| 亚洲午夜久久久影院| 成年人网站免费看| 国产成人在线中文字幕| 欧美一级二级在线观看| 亚洲18在线看污www麻豆| 91国内外精品自在线播放| 色噜噜狠狠成人中文综合 | 亚洲一区二区动漫| 亚州精品天堂中文字幕| 国产精选第一页| 国产精品a久久久久| 欧美成人久久久| 日韩女优一区二区| 欧美a级在线| 欧美成人激情在线| 妺妺窝人体色www婷婷| 欧美一区二区三区久久精品茉莉花| 久久精品一本久久99精品| 永久免费看片直接| 中文av一区| 久久国产精品久久久久久| 手机在线免费看毛片| 91精品久久久久久久久久不卡| 色婷婷av一区二区三区在线观看| 久久久久人妻一区精品色| 色999国产精品| 久久精品国产精品亚洲| 国产精品老熟女一区二区| 欧美~级网站不卡| 欧美高清无遮挡| 懂色av.com| 亚洲综合日韩| 国产97在线播放| 免费黄色片视频| 麻豆成人免费电影| 5g国产欧美日韩视频| 亚洲免费成人网| 26uuu另类欧美亚洲曰本| 日韩精品成人一区二区在线观看| bbbbbbbbbbb在线视频| 一色桃子久久精品亚洲| 少妇大叫太大太粗太爽了a片小说| heyzo高清国产精品| 欧美网站在线观看| 亚洲人视频在线| 中文字幕av一区二区三区四区| 亚洲精品成人久久电影| youjizz亚洲女人| 女生裸体视频一区二区三区| 97精品国产aⅴ7777| 国产99久久久久久免费看| 久久99精品国产麻豆不卡| 9a蜜桃久久久久久免费| 欧美色图另类| 专区另类欧美日韩| 日韩在线视频在线观看| 日本一区二区三区中文字幕| 亚洲第一福利网站| 国精产品一区一区| 99国产精品久久久久久久成人热 | 一区二区三区我不卡| 色图在线观看| 色悠悠亚洲一区二区| 亚洲第一天堂久久| 欧美丝袜足交| 久久亚洲综合国产精品99麻豆精品福利 | 日本久久久网站| 男人皇宫亚洲男人2020| 日韩欧美不卡一区| wwwww黄色| 中文国产一区| 成人在线中文字幕| 国产毛片在线| 红桃视频成人在线观看| 911福利视频| 亚洲免费专区| 久久久久久中文字幕| 亚洲网站在线免费观看| 99精品一区二区三区| 99亚洲精品视频| 欧美aaa大片视频一二区| 亚洲精品一区二区三区福利| 天堂а√在线中文在线鲁大师| 久久www成人_看片免费不卡| 99r国产精品视频| 九七久久人人| 欧美专区在线观看一区| 亚洲天堂网一区二区| 激情91久久| 亚洲永久免费观看| 麻豆影视国产在线观看| 欧美日精品一区视频| 国产一区二区三区四区五区六区| 亚洲第一黄网| 古典武侠综合av第一页| а天堂中文在线官网| 欧美日本不卡视频| 韩国三级hd中文字幕| 中文在线不卡| 久久99国产精品99久久| av中文字幕电影在线看| 日韩欧美不卡一区| 精品少妇theporn| 国产一区二区免费看| 中文字幕中文字幕99| 欧美黑粗硬大| 亚洲精品成a人ⅴ香蕉片| 亚洲va欧美va人人爽| 亚洲午夜精品在线观看| 日韩中文首页| 国产精品午夜一区二区欲梦| 国内精品一区视频| 在线视频国内自拍亚洲视频| a级在线免费观看| 媚黑女一区二区| 日本黄网免费一区二区精品| 国产精品高清乱码在线观看| 一区二区成人精品| 狠狠躁夜夜躁人人爽视频| 久久精品日韩一区二区三区| 男人舔女人下面高潮视频| 国产精品美女久久久久久不卡 | 欧美一区二区国产| 五月天av网站| 国产成人啪午夜精品网站男同| 麻豆映画在线观看| 亚洲第一二区| 91国在线精品国内播放| 免费在线黄色影片| 精品污污网站免费看| 内射一区二区三区| 成人午夜av电影| 每日在线更新av| 国产va免费精品观看精品视频 | 亚洲天堂av高清| 一级片在线观看视频| 一区二区视频在线看| 北京富婆泄欲对白| 日韩中文字幕一区二区三区| 一区二区三区国产福利| 亚洲综合网站| 热草久综合在线| 天天影视久久综合| 精品奇米国产一区二区三区| 天天综合网入口| 国产女人aaa级久久久级| 两性午夜免费视频| 国产欧美综合一区二区三区| 亚洲一区二区三区精品视频| 日韩黄色av| 国产成人精品免高潮费视频| 日本电影在线观看网站| 精品国产一二三| 波多野结衣高清视频| 亚洲精品欧美二区三区中文字幕| 亚洲一级片免费观看| 亚洲免费综合| 7777在线视频| 国产欧美日韩一区二区三区四区| 91九色视频导航| 性欧美videohd高精| 欧美老少做受xxxx高潮| 极品白浆推特女神在线观看 | 婷婷国产精品| 成人在线视频网| 综合日韩av| 九九久久精品一区| 91官网在线| 国产视频精品免费播放| 不卡视频在线播放| 欧美午夜片在线观看| 国产网址在线观看| 国产精品高潮呻吟| 中文字幕av网址| 国产不卡免费视频| 日本黄色福利视频| 日韩精品成人一区二区在线| 丰满的少妇愉情hd高清果冻传媒 | 亚洲www啪成人一区二区| 欧美另类老女人| 日本在线天堂| 伊人男人综合视频网| 天堂网在线中文| 欧美成人精品高清在线播放| 中文字幕人妻丝袜乱一区三区| 精品国产精品三级精品av网址| 欧美成人黄色网| 亚洲天堂中文字幕| 97精品在线播放| 久久精品日韩一区二区三区| av网站有哪些| av福利精品导航| 蜜臀aⅴ国产精品久久久国产老师| 精品一区二区三区在线播放| 天天爱天天操天天干| 久久性色av| 成年人观看网站| 国产亚洲综合精品| 免费av观看网址| 99精品国产一区二区青青牛奶| 日韩a级黄色片| 黄色在线一区| 男的插女的下面视频| 欧美日本亚洲韩国国产| 日本一道在线观看| 牛牛国产精品| 妺妺窝人体色www看人体| 欧美.日韩.国产.一区.二区| www.国产亚洲| 精品1区2区3区4区| 欧美一级片免费播放| 亚洲国产片色| 国产黄页在线观看| 国产美女诱惑一区二区| 成年网站在线免费观看| 视频一区欧美精品| 污污的视频免费| 国内精品视频一区二区三区八戒| 捷克做爰xxxⅹ性视频| 国产精品一区二区视频| 在线观看免费视频黄| 99在线热播精品免费| 国产人妻人伦精品1国产丝袜| 99久久er热在这里只有精品66| 国产精品无码在线| 久久久久久日产精品| 国产第一页精品| 亚洲欧美电影院| 国产精品成人久久| 一本色道综合亚洲| 在线观看毛片视频| 欧美一级电影网站| 午夜在线观看视频18| 在线成人激情视频| 综合久久2019| 7777精品视频| 国精品产品一区| 99久久99久久| 国产区精品区| 三级在线免费观看| 亚洲欧美日韩一区在线观看| 精品999在线| 风流少妇一区二区| 日本性高潮视频| 一区二区三区不卡在线观看| 国产成人愉拍精品久久 | 久久综合久久八八| 老牛影视精品| 国产精选久久久久久| 粉嫩的18在线观看极品精品| 五码日韩精品一区二区三区视频| 欧美在线亚洲| 亚洲一二三区av| 国产一区不卡在线| 国产一区二区三区四区五区六区| 一区二区三区四区高清精品免费观看| 国产精品suv一区二区三区| 欧美日本在线看| 日本免费一区二区三区最新| 久久亚洲国产成人| 欧美va在线| 狠狠色噜噜狠狠狠狠色吗综合 | 日韩不卡一二区| 性xx色xx综合久久久xx| 夜夜爽久久精品91| 中文子幕无线码一区tr| 国产毛片aaa| 日韩三级视频中文字幕| www.91在线| 97在线视频国产| 经典三级久久| 日韩av电影免费观看| 亚洲精品女人| 少妇欧美激情一区二区三区| 国产精品久久三| 久久99国产综合精品免费| 日韩欧美国产一二三区| 最新97超碰在线| 国产精品爱久久久久久久| 黄色网一区二区| 国产精品三级一区二区| 精品制服美女久久| 五月天精品在线| 日韩欧美aaa| 少妇喷水在线观看| 欧美丰满少妇xxxxx做受| 偷拍自拍亚洲| 亚洲精品高清视频| 日本免费新一区视频| 少妇特黄一区二区三区| 欧美日韩色婷婷| 欧美 日韩 人妻 高清 中文| 蜜臀久久99精品久久久久久宅男 | 全球成人中文在线| 亚洲第一福利社区| 日韩在线一级片| 99re视频精品| 香蕉免费毛片视频| 亚洲韩国日本中文字幕| 丁香花在线影院| 国产精品一区二区三区观看 | 久久久精品在线| 免费成人毛片| 正在播放久久| 黑人巨大精品欧美黑白配亚洲| 日本裸体美女视频| 欧美一区二区三区婷婷月色| 在线观看a视频| 成人黄色短视频在线观看| 我不卡神马影院| 国产黄色一区二区三区| 亚洲综合成人在线| 人妻一区二区三区四区| 91高清免费在线观看| 九一成人免费视频| 国产福利影院在线观看| 国产精品国产自产拍高清av王其| 亚洲天堂手机在线| 久久成人国产精品| 99国产精品免费网站| www.射射射| 久久九九久精品国产免费直播| 波多野结衣绝顶大高潮| 在线视频中文亚洲| 成人豆花视频| 黄色一级片黄色| 99久久婷婷国产综合精品| 在线观看日本网站| 日韩在线观看网站| 一区二区三区四区视频免费观看 | 亚洲麻豆av| 亚洲成人黄色av| 欧美日韩精品福利| 在线观看中文字幕的网站| 国产在线一区二区三区播放| 首页国产欧美日韩丝袜| 亚洲人与黑人屁股眼交| 欧美zozozo| 日韩av首页| 亚洲色图都市激情| 97se亚洲国产综合自在线不卡| 久久永久免费视频| 精品国偷自产在线视频| 久久久免费毛片| 91精品无人成人www| 亚洲一区国产视频| 国产三区四区在线观看| 亚洲伊人第一页| 亚洲永久视频| 我要看黄色一级片| 亚洲另类激情图| 国产在线视频欧美一区| 91黄色小网站| 亚洲激情图片小说视频| 男人的天堂av高清在线|