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)了以下兩種類(lèi)型的行鎖。 共享鎖(s):允許一個(gè)事務(wù)去讀一行,阻止其他事務(wù)獲得相同數(shù)據(jù)集的排他鎖。 排他鎖(X):允許獲取排他鎖的事務(wù)更新數(shù)據(jù),阻止其他事務(wù)取得相同的數(shù)據(jù)集共享讀鎖和排他寫(xiě)鎖。另外,為了允許行鎖和表鎖共存,實(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. python - 斗魚(yú)關(guān)注人數(shù)爬下來(lái)是張加載圖片,如何爬取關(guān)注人數(shù)2. javascript - dropload+tab頁(yè)面,圖文頁(yè)滾動(dòng)有兩個(gè)滾動(dòng)區(qū)域怎么破?3. javascript - H5移動(dòng)端開(kāi)發(fā)4. ios - 類(lèi)似微博首頁(yè),一張圖的時(shí)候是如何確定圖大小的?5. php - mysql多表查詢(xún)6. python - 為什么在main()函數(shù)里result 會(huì)變成那樣?7. 修改my.cnf后mysql無(wú)法運(yùn)行???8. 就一臺(tái)服務(wù)器,mysql數(shù)據(jù)庫(kù)想實(shí)現(xiàn)自動(dòng)備份,如何設(shè)計(jì)?9. javascript - CSS圖片輪播顯示問(wèn)題10. 怎么用php+mysql做動(dòng)態(tài)數(shù)據(jù)表格 , 急!!!
