InnoDB 的行鎖模式及加鎖方法

2021-08-22 10:09:49 字數 365 閱讀 3677

innodb 實現了以下兩種型別的行鎖。

 共享鎖(s):允許乙個事務去讀一行,阻止其他事務獲得相同資料集的排他鎖。

 排他鎖(x):允許獲得排他鎖的事務更新資料,阻止其他事務取得相同資料集的共享

讀鎖和排他寫鎖。

另外,為了允許行鎖和表鎖共存,實現多粒度鎖機制,innodb 還有兩種內部使用的意

向鎖(intention locks),這兩種意向鎖都是表鎖。

 意向共享鎖(is):事務打算給資料行加行共享鎖,事務在給乙個資料行加共享鎖前

必須先取得該錶的 is 鎖。

 意向排他鎖(ix):事務打算給資料行加行排他鎖,事務在給乙個資料行加排他鎖前

必須先取得該錶的 ix 鎖。

mysql中innodb引擎的行鎖

一 資料庫引擎 mysql常用的資料庫引擎也就是myisam和innodb兩種,相比較起myisam而言innodb支援了事務 外來鍵等功能,具有更好的併發性支援,所以在大併發的情況的下我們一般選擇的是innodb來作為我們的資料庫儲存引擎,而myisam相較innodb的執行效能上會有更好的表現,...

MySQL鎖 InnoDB行鎖需要避免的坑

換了工作之後,接近半年沒有發部落格了 一直加班 emmmm.今天好不容易有時間,記錄下工作中遇到的一些問題,接下來應該重拾知識點了。因為新公司工作中mysql庫經常出現查詢慢,鎖等待,節點掛掉.等一系列問題。導致每個程式設計師頭都很大,一味抱怨 為什麼我就查一條資料這麼卡 我tm加了索引的啊,怎麼還...

MySQL鎖(四)行鎖的加鎖規則和案例

今天我們就來學習一下加鎖規則吧。在學習前要說明一點,以下的規則只限於版本範圍 5.x系列 5.7.24,8.0系列 8.0.13。這個加鎖規則包含兩個 原則 兩個 優化 和乙個 bug 原則1 加鎖的基本單位是next key lock。希望你還記得,next key lock是前開後閉區間。原則2...