java - innodb 中的行級(jí)別的鎖
問(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ū)分的
相關(guān)文章:
1. mysql 可以從 TCP 連接但是不能從 socket 鏈接2. sql語(yǔ)句 - 如何在mysql中批量添加用戶?3. mysql 非主鍵做范圍查找實(shí)現(xiàn)原理的一點(diǎn)困惑4. java - jdbc如何返回自動(dòng)定義的bean5. 怎么php怎么通過(guò)數(shù)組顯示sql查詢結(jié)果呢,查詢結(jié)果有多條,如圖。6. mysql - 數(shù)據(jù)庫(kù)建字段,默認(rèn)值空和empty string有什么區(qū)別 1107. mysql - JAVA怎么實(shí)現(xiàn)一個(gè)DAO同時(shí)實(shí)現(xiàn)查詢兩個(gè)實(shí)體類的結(jié)果集8. mysql建表索引問(wèn)題求助9. mysql - PHP定時(shí)通知、按時(shí)發(fā)布怎么做?10. 事務(wù) - mysql共享鎖lock in share mode的實(shí)際使用場(chǎng)景
