java - innodb 中的行級別的鎖
問題描述
Innodb 實現了兩種行級別的鎖, 一個是共享鎖,一個是排它鎖。 請問:(1)行級別的鎖是不是只能加載行記錄上? 為什我看到有的地提到表級上也可以共享鎖和排它鎖呢?
各位可以提示下嗎
問題解答
回答1:InnoDB的行鎖只在鎖語句(也就是FOR UPDATE和LOCK IN SHARE MODE)使用到索引時才有效,因為InnoDB鎖的其實是根據索引鎖住行的。也就是說,如果沒有使用索引,鎖就會自動提升到表級別。
回答2:如果樓上所說,在事物隔離級別為repeat read下(mysql默認級別)InnoDB引擎在修改刪除數據時,會先查找到對應的索引,索引都是排序了的,所以會鎖住某個值或者某個范圍。如果這個范圍是整個索引段,那么則整個表數據均會被鎖住;另外沒有索引,在做修改刪除操作的時候會全表掃描數據,自然也會鎖全表。
回答3:InnoDB實現了以下兩種類型的行鎖。 共享鎖(s):允許一個事務去讀一行,阻止其他事務獲得相同數據集的排他鎖。 排他鎖(X):允許獲取排他鎖的事務更新數據,阻止其他事務取得相同的數據集共享讀鎖和排他寫鎖。另外,為了允許行鎖和表鎖共存,實現多粒度鎖機制,InnoDB還有兩種內部使用的意向鎖(Intention Locks),這兩種意向鎖都是表鎖。 意向共享鎖(IS):事務打算給數據行共享鎖,事務在給一個數據行加共享鎖前必須先取得該表的IS鎖。 意向排他鎖(IX):事務打算給數據行加排他鎖,事務在給一個數據行加排他鎖前必須先取得該表的IX鎖。
行鎖是加在行上的,表鎖就是對應整個表。行鎖和表鎖是可以共存的!
回答4:鎖是mysql引擎都有的。行鎖和表鎖是在鎖粒度的角度上區分的
相關文章:
1. docker api 開發的端口怎么獲取?2. golang - 用IDE看docker源碼時的小問題3. 在windows下安裝docker Toolbox 啟動Docker Quickstart Terminal 失敗!4. docker容器呢SSH為什么連不通呢?5. docker - 各位電腦上有多少個容器啊?容器一多,自己都搞混了,咋辦呢?6. docker網絡端口映射,沒有方便點的操作方法么?7. javascript - Tomcat突然就報錯了,解析不了java文件,試過幾個百度的解決方法,沒解決。8. eclipse - 如何解決no atk-wrapper in java.library.path9. angular.js - react的redux和vue的vuex,angular呢10. javascript - 請問微信jssdk自定義分享是不是不能用了?
