99久久久精品免费观看国产,紧身短裙女教师波多野,正在播放暮町ゆう子在线观看,欧美激情综合色综合啪啪五月

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > InnoDB的next-key lock為什么是左開右閉的?

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

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

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

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

select * from t where c2 = 10 for update;

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

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

例如,當(dāng)前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 這個輔助索引,其索引記錄真實(shí)的值是下面這樣的(要包含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隔離級別)事務(wù)期間,這兩個gap也不會插入c2=10的記錄,而導(dǎo)致發(fā)生幻讀。

延伸閱讀:

二、InnoDB是什么

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

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

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
mysql inner join為什么不走索引?

一、mysql inner join為什么不走索引因?yàn)樗饕膬?yōu)勢是在大表中過濾出小的結(jié)果集進(jìn)行聯(lián)接,mysql inner join句根本沒有任何過濾條件。另外表很小...詳情>>

2023-10-11 23:07:14
Geode和redis兩個分布式內(nèi)存數(shù)據(jù)庫的對比,優(yōu)缺點(diǎn)?

一、Geode和redis兩個分布式內(nèi)存數(shù)據(jù)庫的對比兩者的定位不一樣。Geode是分布式內(nèi)存數(shù)據(jù)庫,提供了可配置的一致性保證,能夠保證數(shù)據(jù)不丟失,更...詳情>>

2023-10-11 22:50:49
InnoDB的next-key lock為什么是左開右閉的?

一、InnoDB的next-key lock為什么是左開右閉的InnoDB的next-key lock本身的設(shè)計方案就是左開右閉的,例如select * from t where c2 = 10 fo詳情>>

2023-10-11 22:48:02
到底哪些APP在用Flutter?

一、滴滴出行滴滴出行是一款出行服務(wù)平臺,提供打車、順風(fēng)車、單車等多種出行方式。在采用Flutter技術(shù)后,滴滴出行成功實(shí)現(xiàn)了Android和iOS平臺...詳情>>

2023-10-11 22:45:35
web前端和UI前端的區(qū)別?

一、職責(zé)不同Web前端主要負(fù)責(zé)開發(fā)網(wǎng)站的前端部分,通過編寫代碼實(shí)現(xiàn)網(wǎng)站的用戶界面和交互功能。而UI前端(也稱為UI設(shè)計師或UI工程師)負(fù)責(zé)設(shè)計...詳情>>

2023-10-11 22:40:09
快速通道
主站蜘蛛池模板: 亚洲免费观看视频| 欧美猛交| 真实乱l仑全部视频| 美国式禁忌4桥矿超棒| 骚虎影院在线观看| 在线中文字幕第一页| 成年女人免费播放影院| 波多野结衣全部系列在线观看| 亚洲午夜久久久久久尤物| 亚洲码欧美码一区二区三区| yy6080理论午夜一级毛片| 免费大片黄在线观看| 超污视频在线观看| 欧美日韩电影网| 国产精品国色综合久久| 国产三级在线免费| 日韩精品一卡2卡3卡4卡三卡| 日本精品久久久久中文字幕| 国产青草视频免费观看97| 精品卡2卡3卡4卡免费| 香蕉av影院| 女人张开腿等男人桶免费视频| 亚洲欧美精品一中文字幕| 护士的小嫩嫩好紧好爽在线播放| 777奇米四色米奇影院在线播放| 亚洲欧美日韩国产精品一区| 可以直接看的毛片| 中文字幕精品视频在线观| 再来一次好吗动漫免费观看| 女主调教贱女m视频| 国产毛片儿| 精品卡2卡3卡4卡免费| 国产精品久久久久久久久电影网| 翁公厨房嫒媛猛烈进出| 亚洲激情影院| 处女的诱惑在线观看| 美女奶口隐私免费视频网站| 尤物精品视频一区二区三区| 一本一本久久a久久精品综合麻豆| 好想吃你的馒头| 网曝门精品国产事件在线观看|