樂觀所 悲觀鎖

2021-08-15 00:03:23 字數 421 閱讀 5569

悲觀鎖

具有排他性,在讀取資料後,會在這條資料上加鎖,其他使用者是操作不了這條資料的。

一般用於事務較短,併發不大的場景。

樂觀鎖其實是一種思想,每次讀取資料的時候不會加鎖,但是在進行更新操作的時候,需要判斷

在次之前資料是否被更改過(可以使用版本號等方法),如果資料已經被更改了則拒絕本次

更新操作,在最新的資料之後進行重試。

例如:使用自增長的整數表示資料版本號。更新時檢查版本號是否一致,比如資料庫中資料版本為6,更新提交時version=6+1,使用該version值(=7)與資料庫version+1(=7)作比較,如果相等,則可以更新,如果不等則有可能其他程式已更新該記錄,所以返回錯誤。

樂觀鎖可以避免長事務中在資料庫上加鎖的開銷,提高了系統的吞吐量

但是樂觀鎖機制是基於系統邏輯,所以具有一定的侷限性。

樂觀鎖和悲觀所

簡單的樂觀鎖實現 更新的時候給版本號字段加上 1,然後 update 會返回乙個更新結果的行數,通過這個行數去判斷。update 必須這樣寫 update t user u set u.address address u.version u.version 1 where u.username us...

悲觀鎖樂觀鎖

1 悲觀鎖,正如其名,它指的是對資料被外界 包括本系統當前的其他事務,以及來自外部系統的事務處理 修改持保守態度,因此,在整個資料處理過程中,將資料處於鎖定狀態。悲觀鎖的實現,往往依靠資料庫提供的鎖機制 也只有資料庫層提供的鎖機制才能真正保證資料訪問的排他性,否則,即使在本系統中實現了加鎖機制,也無...

樂觀鎖 悲觀鎖

悲觀鎖 pessimistic lock 顧名思義,就是很悲觀,每次去拿資料的時候都認為別人會修改,所以每次在拿資料的時候都會上鎖,這樣別人想拿這個資料就會block直到它拿到鎖。傳統的關係型資料庫裡邊就用到了很多這種鎖機制,比如行鎖,表鎖等,讀鎖,寫鎖等,都是在做操作之前先上鎖。樂觀鎖 optim...