国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > InnoDB的next-key lock為什么是左開右閉的?

InnoDB的next-key lock為什么是左開右閉的?

來源:千鋒教育
發布人:xqq
時間: 2023-10-11 22:48:02 1697035682

一、InnoDB的next-key lock為什么是左開右閉的

InnoDB的next-key lock本身的設計方案就是左開右閉的,例如

select * from t where c2 = 10 for update;

則鎖定的是 c2=10 這條記錄本身,以及其索引節點上 c2=10 前面的那個gap。

但在RR隔離級別中,為了避免發生幻讀,需要把所有可能插入 c2=10 這個值的位置都加上鎖,所以對 i=10 后面的gap也會加鎖。

例如,當前t表上的值有以下(id列是主鍵,c2列是普通索引,c3列無索引)

id? c2? c3

1?? 1?? 1

2?? 3?? 2

10? 5?? 10

15? 15? 15

20? 10? 20

30? 20? 20

那么對于 c2 這個輔助索引,其索引記錄真實的值是下面這樣的(要包含id列值,innodb的特性決定的)

c2? id

1?? 1

3?? 2

5?? 10

10? 20

15? 15

20? 30

那么上面的加鎖請求

select * from t where c2 = 10 for update;

真正要加鎖的范圍是 (5, 15),也就是說,除了 c2 = 10 這條記錄外,還要對 5~10、10~15這兩個gap也加上鎖,才能保證(RR隔離級別)事務期間,這兩個gap也不會插入c2=10的記錄,而導致發生幻讀。

延伸閱讀:

二、InnoDB是什么

InnoDB 是 MySQL 上名列前茅個提供外鍵約束的數據存儲引擎,除了提供事務處理外,InnoDB 還支持行鎖,提供和 Oracle 一樣的一致性的不加鎖讀取,能增加并發讀的用戶數量并提高性能,不會增加鎖的數量。InnoDB 的設計目標是處理大容量數據時最大化性能,它的 CPU 利用率是其他所有基于磁盤的關系數據庫引擎中最有效率的。

InnoDB 是一套放在 MySQL 后臺的完整數據庫系統,InnoDB 有它自己的緩沖池,能緩沖數據和索引,InnoDB 還把數據和索引存放在表空間里面,可能包含好幾個文件,這和 MyISAM 表完全不同,在 MyISAM 中,表被存放在單獨的文件中,InnoDB 表的大小只受限于操作系統文件的大小,一般為 2GB。

聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT