java - innodb 中的行級別的鎖
問題描述
Innodb 實現(xiàn)了兩種行級別的鎖, 一個是共享鎖,一個是排它鎖。 請問:(1)行級別的鎖是不是只能加載行記錄上? 為什我看到有的地提到表級上也可以共享鎖和排它鎖呢?
各位可以提示下嗎
問題解答
回答1:InnoDB的行鎖只在鎖語句(也就是FOR UPDATE和LOCK IN SHARE MODE)使用到索引時才有效,因為InnoDB鎖的其實是根據(jù)索引鎖住行的。也就是說,如果沒有使用索引,鎖就會自動提升到表級別。
回答2:如果樓上所說,在事物隔離級別為repeat read下(mysql默認級別)InnoDB引擎在修改刪除數(shù)據(jù)時,會先查找到對應(yīng)的索引,索引都是排序了的,所以會鎖住某個值或者某個范圍。如果這個范圍是整個索引段,那么則整個表數(shù)據(jù)均會被鎖住;另外沒有索引,在做修改刪除操作的時候會全表掃描數(shù)據(jù),自然也會鎖全表。
回答3:InnoDB實現(xiàn)了以下兩種類型的行鎖。 共享鎖(s):允許一個事務(wù)去讀一行,阻止其他事務(wù)獲得相同數(shù)據(jù)集的排他鎖。 排他鎖(X):允許獲取排他鎖的事務(wù)更新數(shù)據(jù),阻止其他事務(wù)取得相同的數(shù)據(jù)集共享讀鎖和排他寫鎖。另外,為了允許行鎖和表鎖共存,實現(xiàn)多粒度鎖機制,InnoDB還有兩種內(nèi)部使用的意向鎖(Intention Locks),這兩種意向鎖都是表鎖。 意向共享鎖(IS):事務(wù)打算給數(shù)據(jù)行共享鎖,事務(wù)在給一個數(shù)據(jù)行加共享鎖前必須先取得該表的IS鎖。 意向排他鎖(IX):事務(wù)打算給數(shù)據(jù)行加排他鎖,事務(wù)在給一個數(shù)據(jù)行加排他鎖前必須先取得該表的IX鎖。
行鎖是加在行上的,表鎖就是對應(yīng)整個表。行鎖和表鎖是可以共存的!
回答4:鎖是mysql引擎都有的。行鎖和表鎖是在鎖粒度的角度上區(qū)分的
相關(guān)文章:
1. docker鏡像push報錯2. Docker for Mac 創(chuàng)建的dnsmasq容器連不上/不工作的問題3. 關(guān)docker hub上有些鏡像的tag被標記““This image has vulnerabilities””4. docker - 如何修改運行中容器的配置5. javascript - 請指條明路,angular的$event,在select中卻是undefined?6. java - 如何點擊按鈕,重新運行(我是初學者)?7. html5和Flash對抗是什么情況?8. javascript - 在 model里定義的 引用表模型時,model為undefined。9. docker 下面創(chuàng)建的IMAGE 他們的 ID 一樣?這個是怎么回事????10. phpstudy8.1沒集成mysql-front

網(wǎng)公網(wǎng)安備