鎖表

最后更新于:2022-04-01 06:09:39

# 鎖表 (Lock Table) ### 定義 在要更新資料表的資料時,`MySQL`會將表資料鎖定無法讀取,直到資料異動完畢,`MyISAM` 預設支援 `Table-level lock`,而 `InnoDB` 預設支援 `Row-level lock` ### Table-level lock 資料表資料異動時,將「`整個資料表(Table)`」都鎖定住無法讀取 ### Row-level lock 資料表資料異動時,將「`要更新的資料列(row)`」都鎖定住無法讀取 ### 注意事項 在使用 `Row-level lock` 時必需要 `明確指定要異動資料的主鍵(Primary Key)`,否則將會改用 `Table-level lock` 去做資料表的異動 ### 範例 假設有 user 資料表,裡面有 id 與 name 的欄位,id 是主鍵 | SQL | Table lock | Row lock | No lock | 備註 | |-----|-----|-----|-----|-----| | SELECT * FROM user WHERE id='1' FOR UPDATE; | - | v | - | 明確指定主鍵,並且有此筆資料,row lock | | SELECT * FROM user WHERE id='-1' FOR UPDATE; | - | - | v | 明確指定主鍵,若查無此筆資料,無 lock | | SELECT * FROM user WHERE name='KeJyun' FOR UPDATE; | v | - | - | 無主鍵,table lock | | SELECT * FROM user WHERE id<>'1' FOR UPDATE; | v | - | - | 主鍵不明確,table lock | | SELECT * FROM user WHERE id LIKE '3' FOR UPDATE; | v | - | - | 主鍵不明確,table lock | ### 備註 FOR UPDATE 僅適用於 InnoDB,且必須在交易區塊(BEGIN/COMMIT)中才能生效。 ### 參考資料 - [KeJyun學習日誌: MySQL鎖表(Lock Table)Table-level與Row-level比較](http://blog.kejyun.com/2012/12/Compare-Tabel-And-Row-Level-Lock-On-MySQL.html)
';