mysql的行鎖如何加鎖

我一直記手寫(xiě)筆記剩拢,一個(gè)是手寫(xiě)筆記更靈活好操作线得,另一個(gè)就是比較方便
但我想,如果我寫(xiě)電子筆記徐伐,那么面試的時(shí)候我就可以寫(xiě)在簡(jiǎn)歷上贯钩,以后就是我的亮點(diǎn)

一、行鎖種類
1呵晨、Record Lock 2
2魏保、Gap Lock (2,3)
3、Next-Key Lock (2,3]
(這些都在我的手寫(xiě)筆記里摸屠,今天著急學(xué)新知識(shí)谓罗,就不擴(kuò)展了)
二、
InnoDB是支持行鎖的季二,行鎖是在索引上面加鎖的檩咱,加鎖的基本單位是Next-Key Lock,但是也會(huì)存在鎖降級(jí)的情況胯舷,Next-Key Lock降級(jí)為Record或者Gap刻蚯。
下面分為四種情況分別介紹:
· 唯一索引等值查詢
· 唯一索引范圍查詢
· 非唯一索引等值查詢
· 非唯一索引范圍查詢

1、唯一索引等值查詢

(1)這條記錄存在于數(shù)據(jù)庫(kù)


正常是加Next-Key Lock桑嘶,但是這條命令select * from user where id = 1 for update;只查一條炊汹,而且主鍵索引的時(shí)候,它也存在逃顶,加Next-Key Lock讨便,(1,1]這樣就有點(diǎn)浪費(fèi)且奇怪充甚,可以降級(jí)為Record鎖,只鎖住id=1這條就可以了霸褒。
這條記錄的行鎖是Record鎖,表鎖是IX鎖伴找。那么當(dāng)其它update或者delete語(yǔ)句操作這條id=1時(shí),因?yàn)橛墟i废菱,其余的操作就會(huì)在后面阻塞技矮。

為什么唯一索引等值查詢并且查詢記錄存在的場(chǎng)景下,該記錄的索引中的 next-key lock 會(huì)退化成記錄鎖殊轴?

原因就是在唯一索引等值查詢并且查詢記錄存在的場(chǎng)景下衰倦,僅靠記錄鎖也能避免幻讀的問(wèn)題。

幻讀的定義就是旁理,當(dāng)一個(gè)事務(wù)前后兩次查詢的結(jié)果集耿币,不相同時(shí),就認(rèn)為發(fā)生幻讀韧拒。
所以,要避免幻讀就是避免結(jié)果集某一條記錄被其他事務(wù)刪除十性,或者有其他事務(wù)插入了一條新記錄叛溢,
這樣前后兩次查詢的結(jié)果集就不會(huì)出現(xiàn)不相同的情況。

(2)這條記錄不存在于數(shù)據(jù)庫(kù)


還是上面的那個(gè)數(shù)據(jù)庫(kù)表示例劲适,主鍵索引1楷掉,然后就是5,發(fā)現(xiàn)5大于2霞势,這個(gè)時(shí)候就會(huì)將Next-Key Lock降級(jí)為Gap Lock烹植,鎖住(1愕贡,5)


2草雕、唯一索引范圍查詢

· 大于 or 大于等于
· 小于 or 小于等于

(1)大于

事務(wù) A 加鎖變化過(guò)程如下:

最開(kāi)始要找的第一行是 id = 20,由于查詢?cè)撚涗洸皇且粋€(gè)等值查詢(不是大于等于條件查詢)固以,
所以對(duì)該主鍵索引加的是范圍為 (15, 20] 的 next-key 鎖墩虹;
由于是范圍查找,就會(huì)繼續(xù)往后找存在的記錄憨琳,雖然我們看見(jiàn)表中最后一條記錄是 id = 20 的記錄诫钓,
但是實(shí)際在 Innodb 存儲(chǔ)引擎中,會(huì)用一個(gè)特殊的記錄來(lái)標(biāo)識(shí)最后一條記錄篙螟,
該特殊的記錄的名字叫 supremum pseudo-record 菌湃,所以掃描第二行的時(shí)候,
也就掃描到了這個(gè)特殊記錄的時(shí)候遍略,會(huì)對(duì)該主鍵索引加的是范圍為 (20, +∞] 的 next-key 鎖惧所。
停止掃描骤坐。

(2)大于等于


(3)小于

1)查詢條件值的記錄「不存在」表中的情況

2)查詢條件值的記錄「存在」表中的情況

(4)小于等于

1)查詢條件值的記錄「存在」表中的情況

3、非唯一索引等值查詢

說(shuō)這個(gè)之前還是得再看一下建表語(yǔ)句


(1)針對(duì)非唯一索引等值查詢時(shí)纯路,查詢的值不存在的情況或油。




(2)查詢的值存在的情況



因?yàn)槭嵌?jí)索引,所以age=22如果存在驰唬,可能不是一個(gè)顶岸,所以加鎖比較特殊,一個(gè)next-key,一個(gè)gap



gap鎖或者是next-key叫编,二級(jí)索引加鎖的時(shí)候辖佣,假如說(shuō)二級(jí)鎖(age)是(21,22) or (21,22]搓逾,age=21時(shí)卷谈,id=5,那么插入21霞篡,id<5的都可以插入成功世蔗,但如果id>=5就會(huì)阻塞
同理age=22,id=10,插入age=22、id<=10就會(huì)被阻塞朗兵,id>10就會(huì)成功污淋、、(如果只有這一個(gè)gap鎖的話余掖,如果還有相鄰的gap鎖還要繼續(xù)去判斷)
為什么這個(gè)實(shí)驗(yàn)案例中寸爆,需要在二級(jí)索引索引上加范圍 (22, 39) 的間隙鎖?

簡(jiǎn)單來(lái)說(shuō)就是盐欺,如果只加(21,22]的next-key鎖赁豆,只會(huì)鎖住age=22對(duì)應(yīng)id的左邊,右邊的id沒(méi)有上鎖冗美,那么就會(huì)出現(xiàn)幻讀現(xiàn)象


4魔种、非唯一索引范圍查詢


5、沒(méi)有加索引的查詢

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末墩衙,一起剝皮案震驚了整個(gè)濱河市务嫡,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌漆改,老刑警劉巖心铃,帶你破解...
    沈念sama閱讀 212,816評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異挫剑,居然都是意外死亡去扣,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)愉棱,“玉大人唆铐,你說(shuō)我怎么就攤上這事”蓟” “怎么了艾岂?”我有些...
    開(kāi)封第一講書(shū)人閱讀 158,300評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)朋其。 經(jīng)常有香客問(wèn)我王浴,道長(zhǎng),這世上最難降的妖魔是什么梅猿? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,780評(píng)論 1 285
  • 正文 為了忘掉前任氓辣,我火速辦了婚禮,結(jié)果婚禮上袱蚓,老公的妹妹穿的比我還像新娘钞啸。我一直安慰自己,他們只是感情好喇潘,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,890評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布体斩。 她就那樣靜靜地躺著,像睡著了一般颖低。 火紅的嫁衣襯著肌膚如雪硕勿。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 50,084評(píng)論 1 291
  • 那天枫甲,我揣著相機(jī)與錄音,去河邊找鬼扼褪。 笑死想幻,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的话浇。 我是一名探鬼主播脏毯,決...
    沈念sama閱讀 39,151評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼幔崖!你這毒婦竟也來(lái)了食店?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,912評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤赏寇,失蹤者是張志新(化名)和其女友劉穎吉嫩,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體嗅定,經(jīng)...
    沈念sama閱讀 44,355評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡自娩,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,666評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了渠退。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片忙迁。...
    茶點(diǎn)故事閱讀 38,809評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡脐彩,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出姊扔,到底是詐尸還是另有隱情惠奸,我是刑警寧澤,帶...
    沈念sama閱讀 34,504評(píng)論 4 334
  • 正文 年R本政府宣布恰梢,位于F島的核電站佛南,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏删豺。R本人自食惡果不足惜共虑,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,150評(píng)論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望呀页。 院中可真熱鬧妈拌,春花似錦、人聲如沸蓬蝶。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)丸氛。三九已至培愁,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間缓窜,已是汗流浹背定续。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,121評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留禾锤,地道東北人私股。 一個(gè)月前我還...
    沈念sama閱讀 46,628評(píng)論 2 362
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像恩掷,于是被迫代替她去往敵國(guó)和親倡鲸。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,724評(píng)論 2 351

推薦閱讀更多精彩內(nèi)容