MySQL中的鎖類型都有哪些
MySQL 中的鎖機制是保障事務隔離性和并發(fā)控制的核心組件,主要分為以下類型,按作用范圍和場景分類如下:
一、按鎖粒度分類
1. 表級鎖(Table-Level Locking)
特性:鎖定整張表,開銷小但并發(fā)性低。
常見類型:
- 表共享鎖(LOCK TABLES … READ):允許其他事務讀表,但禁止寫操作。
- 表排他鎖(LOCK TABLES … WRITE):禁止其他事務讀寫表。
意向鎖(Intention Locks):
- 意向共享鎖(IS):事務打算在行上加共享鎖。
- 意向排他鎖(IX):事務打算在行上加排他鎖。
- 作用:作為表級鎖,與行級鎖兼容性判斷的標識,優(yōu)化鎖沖突檢測。
2. 行級鎖(Row-Level Locking)
特性:僅鎖定數(shù)據(jù)行,開銷大但并發(fā)性高(InnoDB 默認支持)。
常見類型:
- 記錄鎖(Record Locks):鎖定索引中的單條記錄。
- 間隙鎖(Gap Locks):鎖定索引記錄之間的“間隙”,防止插入新數(shù)據(jù)(解決幻讀)。
- 臨鍵鎖(Next-Key Locks):記錄鎖 + 間隙鎖的組合,鎖定記錄本身及前一個間隙(InnoDB 默認鎖模式)。
二、按鎖模式分類
1. 共享鎖(Shared Lock,S鎖)
- 特性:允許其他事務讀取數(shù)據(jù),但禁止修改。
- 使用場景:
SELECT ... LOCK IN SHARE MODE。
2. 排他鎖(Exclusive Lock,X鎖)
- 特性:禁止其他事務讀寫數(shù)據(jù)。
- 使用場景:
SELECT ... FOR UPDATE或自動由INSERT/UPDATE/DELETE觸發(fā)。
三、特殊場景鎖
1. 自增鎖(AUTO-INC Locks)
- 特性:針對
AUTO_INCREMENT列,確保自增值唯一且連續(xù)。 - 行為:在插入語句執(zhí)行時短暫持有,可能成為并發(fā)瓶頸。
2. 插入意向鎖(Insert Intention Locks)
- 特性:當事務嘗試插入數(shù)據(jù)到已鎖定的間隙時,設置插入意向鎖,表示等待間隙釋放。
- 作用:避免插入沖突,提高并發(fā)插入效率。
3. 元數(shù)據(jù)鎖(Metadata Locks,MDL)
特性:隱式加鎖,管理對表結構的并發(fā)訪問(如 DDL 操作)。
行為:
- 修改表結構時(
ALTER TABLE),自動請求元數(shù)據(jù)排他鎖。 - 其他事務若持有該表的元數(shù)據(jù)鎖,需等待釋放。
四、存儲引擎差異
- InnoDB:支持行級鎖、間隙鎖、臨鍵鎖,默認隔離級別為
REPEATABLE READ。 - MyISAM:僅支持表級鎖,無行級鎖,并發(fā)性能較低。
五、鎖行為與隔離級別關系
| 隔離級別 | 鎖類型 | 特點 |
|---|---|---|
| 讀未提交 | 無間隙鎖,僅記錄鎖 | 允許臟讀,鎖競爭最少 |
| 讀已提交 | 記錄鎖(MVCC) | 通過快照讀避免臟讀,但可能幻讀 |
| 可重復讀(默認) | 臨鍵鎖(Next-Key Locks) | 默認鎖模式,防止幻讀,但可能增加鎖競爭 |
| 串行化 | 強制表級鎖或間隙鎖 | 完全串行執(zhí)行,性能最低 |
六、使用建議
- 優(yōu)化索引:合理設計索引可減少鎖范圍(如唯一索引避免間隙鎖)。
- 控制事務粒度:避免長時間持有鎖,減少鎖競爭。
- 監(jiān)控鎖狀態(tài):通過
SHOW ENGINE INNODB STATUS或INFORMATION_SCHEMA.INNODB_LOCKS分析鎖沖突。 - 隔離級別選擇:根據(jù)業(yè)務需求權衡一致性與并發(fā)性能(如讀已提交 + 索引優(yōu)化)。
通過理解鎖類型和行為,可有效優(yōu)化 MySQL 并發(fā)性能,避免死鎖和性能瓶頸。
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
mysql數(shù)據(jù)庫SQL子查詢(史上最詳細)
這篇文章主要給大家介紹了關于mysql數(shù)據(jù)庫SQL子查詢的相關資料,子查詢指的是嵌套在某個語句中的SELECT語句, MySQL支持標準SQL所要求的所有子查詢形式和操作,此外還進行了一些擴展,需要的朋友可以參考下2024-05-05
MySQL?時間類型用?datetime,?timestamp?還是?integer?更好
這篇文章主要介紹了MySQL?時間類型用datetime,timestamp還是integer更好,文章通過圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-09-09
Mysql的Table doesn't exist問題及解決
這篇文章主要介紹了Mysql的Table doesn't exist問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12
InnoDB的關鍵特性-插入緩存,兩次寫,自適應hash索引詳解
下面小編就為大家?guī)硪黄狪nnoDB的關鍵特性-插入緩存,兩次寫,自適應hash索引詳解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-03-03

