成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

java - innodb 中的行級(jí)別的鎖

瀏覽:99日期:2023-12-05 15:08:13

問(wèn)題描述

Innodb 實(shí)現(xiàn)了兩種行級(jí)別的鎖, 一個(gè)是共享鎖,一個(gè)是排它鎖。 請(qǐng)問(wèn):(1)行級(jí)別的鎖是不是只能加載行記錄上? 為什我看到有的地提到表級(jí)上也可以共享鎖和排它鎖呢?

各位可以提示下嗎

問(wèn)題解答

回答1:

InnoDB的行鎖只在鎖語(yǔ)句(也就是FOR UPDATE和LOCK IN SHARE MODE)使用到索引時(shí)才有效,因?yàn)镮nnoDB鎖的其實(shí)是根據(jù)索引鎖住行的。也就是說(shuō),如果沒(méi)有使用索引,鎖就會(huì)自動(dòng)提升到表級(jí)別。

回答2:

如果樓上所說(shuō),在事物隔離級(jí)別為repeat read下(mysql默認(rèn)級(jí)別)InnoDB引擎在修改刪除數(shù)據(jù)時(shí),會(huì)先查找到對(duì)應(yīng)的索引,索引都是排序了的,所以會(huì)鎖住某個(gè)值或者某個(gè)范圍。如果這個(gè)范圍是整個(gè)索引段,那么則整個(gè)表數(shù)據(jù)均會(huì)被鎖住;另外沒(méi)有索引,在做修改刪除操作的時(shí)候會(huì)全表掃描數(shù)據(jù),自然也會(huì)鎖全表。

回答3:

InnoDB實(shí)現(xiàn)了以下兩種類型的行鎖。 共享鎖(s):允許一個(gè)事務(wù)去讀一行,阻止其他事務(wù)獲得相同數(shù)據(jù)集的排他鎖。 排他鎖(X):允許獲取排他鎖的事務(wù)更新數(shù)據(jù),阻止其他事務(wù)取得相同的數(shù)據(jù)集共享讀鎖和排他寫鎖。另外,為了允許行鎖和表鎖共存,實(shí)現(xiàn)多粒度鎖機(jī)制,InnoDB還有兩種內(nèi)部使用的意向鎖(Intention Locks),這兩種意向鎖都是表鎖。 意向共享鎖(IS):事務(wù)打算給數(shù)據(jù)行共享鎖,事務(wù)在給一個(gè)數(shù)據(jù)行加共享鎖前必須先取得該表的IS鎖。 意向排他鎖(IX):事務(wù)打算給數(shù)據(jù)行加排他鎖,事務(wù)在給一個(gè)數(shù)據(jù)行加排他鎖前必須先取得該表的IX鎖。

行鎖是加在行上的,表鎖就是對(duì)應(yīng)整個(gè)表。行鎖和表鎖是可以共存的!

回答4:

鎖是mysql引擎都有的。行鎖和表鎖是在鎖粒度的角度上區(qū)分的

標(biāo)簽: java
相關(guān)文章: