java項目中如何使用mysql行鎖

mysql中的行鎖,分爲兩種:共享鎖排它鎖

共享鎖允許事物讀一行記錄,不允許任何線程對該行記錄進行修改。

排他鎖允許當前事物刪除或更新一行記錄,其他線程不能操作該記錄。

共享鎖

SELECT * FROM TABLE LOCK IN SHARE MODE;

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

1. 使用共享鎖線程可對其鎖定記錄進行讀取,其他線程同樣也可對鎖定記錄進行讀取操作,並且這兩個線程讀取的數據都屬於同一個版本。

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

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

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

排它鎖

SELECT * FROM TABLE FOR UPDATE

UPDATE

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

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

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

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

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

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章