c mysql加鎖 MySQL鎖的用法之行級鎖

2021-10-19 02:17:16 字數 1548 閱讀 8255

行級鎖是 mysql 中粒度最小的一種鎖,他能大大減少 資料庫 操作的衝突。但是粒度越小,實現的成本也越高。 myisam 引擎只支援表級鎖,而 innodb 引擎能夠支援行級鎖,下面的內容也是針對innodb行級鎖展開的。

innodb的行級鎖有共享鎖(s lock)和排他鎖(x lock)兩種。共享鎖允許事物讀一行記錄,不允許任何執行緒對該行記錄進行修改。排他鎖允許當前事物刪除或更新一行記錄,其他執行緒不能操作該記錄。

共享鎖:

用法: select ... lock in share mode;

mysql會對查詢結果集中每行都新增共享鎖。

鎖申請前提:當前沒有執行緒對該結果集中的任何行使用排他鎖,否則申請會阻塞。

操作限制:

使用共享鎖線程與不使用共享鎖線程對鎖定記錄操作限制表

執行緒 讀取操作 寫入操作 共享鎖申請 排他鎖申請

使用共享鎖 可讀 可寫/不可寫(報錯) 可申請 可申請

不使用共享鎖 可讀 不可寫(阻塞) 可申請 不可申請(阻塞)

使用共享鎖線程可對其鎖定記錄進行讀取,其他執行緒同樣也可對鎖定記錄進行讀取操作,並且這兩個執行緒讀取的資料都屬於同乙個版本。

對於寫入操作,使用共享鎖的執行緒需要分情況討論,當只有當前執行緒對指定記錄使用共享鎖時,執行緒是可對該記錄進行寫入操作(包括更新與刪除),這是由於在寫入操作前,執行緒向該記錄申請了排他鎖,然後才進行寫入操作;當其他執行緒也對該記錄使用共享鎖時,則不可進行寫入操作,系統會有報錯提示。不對鎖定記錄使用共享鎖的執行緒,當然是不可進行寫入操作了,寫入操作會阻塞。

使用共享鎖程序可再次對鎖定記錄申請共享鎖,系統並不報錯,但是操作本身並沒有太大意義。其他執行緒同樣也可以對鎖定記錄申請共享鎖。

使用共享鎖程序可對其鎖定記錄申請排他鎖;而其他程序是不可以對鎖定記錄申請排他鎖,申請會阻塞。

排他鎖:

用法: select ... for update;

mysql會對查詢結果集中每行都新增排他鎖,在事物操作中,任何對記錄的更新與刪除操作會自動加上排他鎖。

鎖申請前提:當前沒有執行緒對該結果集中的任何行使用排他鎖或共享鎖,否則申請會阻塞。

操作限制:

使用排他鎖線程與不使用排他鎖線程對鎖定記錄操作限制表

執行緒 讀取操作 寫入操作 共享鎖申請 排他鎖申請

使用排他鎖 可讀(新版本) 可寫 可申請 可申請

不使用排他鎖 可讀(舊版本) 不可寫(阻塞) 不可申請(阻塞) 不可申請(阻塞)

使用排他鎖線程可以對其鎖定記錄進行讀取,讀取的內容為當前事物的最新版本;而對於不使用排他鎖的執行緒,同樣是可以進行讀取操作,這種特性是一致性非鎖定讀。即對於同一條記錄,資料庫記錄多個版本,在事物內的更新操作會反映到新版本中,而舊版本會提供給其他執行緒進行讀取操作。

使用排他鎖線程可對其鎖定記錄進行寫入操作;對於不使用排他鎖的執行緒,對鎖定記錄的寫操作是不允許的,請求會阻塞。

使用排他鎖程序可對其鎖定記錄申請共享鎖,但是申請共享鎖之後,執行緒並不會釋放原先的排他鎖,因此該記錄對外表現出排他鎖的性質;其他執行緒是不可對已鎖定記錄申請共享鎖,請求會阻塞。

使用排他鎖程序可對其鎖定記錄申請排他鎖(實際上並沒有任何意義);而其他程序是不可對鎖定記錄申請排他鎖,申請會阻塞。

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

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

MySQL的加鎖規則

首先是課程中的總結的加鎖規則,兩個 原則 兩個 優化 和乙個 bug 可重複讀的事務隔離級別下 原則 1 加鎖的基本單位是 next key lock。希望你還記得,next key lock 是前開後閉區間。原則 2 查詢過程中訪問到的物件才會加鎖。優化 1 索引上的等值查詢,給唯一索引加鎖的時候...

mysql自定義加鎖 為MySQL加鎖?

在日常操作中,update insert delete innodb會自動給涉及的資料集加排他鎖,一般的 select 一般是不加任何鎖的。我們可以使用以下方式顯示的為 select 加鎖。共享鎖 select from table name where id 10 lock in share mo...