資料庫庫存扣減樂觀鎖使用

2022-08-15 15:12:09 字數 1078 閱讀 5091

資料庫加樂觀鎖:

使用資料版本(version)記錄機制實現,這是樂觀鎖最常用的一種實現方式。何謂資料版本?即為資料增加乙個版本標識,一般是通過為資料庫表增加乙個數字型別的 「version」 欄位來實現。當讀取資料時,將version欄位的值一同讀出,資料每更新一次,對此version值加一。當我們提交更新的時候,判斷資料庫表對應記錄的當前版本資訊與第一次取出來的version值進行比對,如果資料庫表當前版本號與第一次取出來的version值相等,則予以更新,否則認為是過期資料

舉例:i.資料庫表設計

task

有三個字段,分別是id,value、version

ii.實現

1)先讀task表的資料(實際上這個表只有一條記錄),得到version的值為versionvalue

2)每次更新task表中的value欄位時,為了防止發生衝突,需要這樣操作

update task set value = newvalue,version =  versionvalue + 1   where version = versionvalue;

只有這條語句執行了,才表明本次更新value欄位的值成功

如假設有兩個節點a和b都要更新task表中的value字段值,差不多在同一時刻,a節點和b節點從task表中讀到的version值為2,那麼a節點和b節點在更新value字段值的時候,都操作 update task set value = newvalue,version =  3   where version = 2;,實際上只有1個節點執行該sql語句成功,假設a節點執行成功,那麼此時task表的version欄位的值是3,b節點再操作update task set value = newvalue,version =  3   where version = 2;這條sql語句是不執行的,這樣就保證了更新task表時不發生衝突

mybatis實際使用:

表結構:

資料庫樂觀鎖

百上千個併發,這樣的情況將導致怎樣的後果。樂觀鎖機制在一定程度上解決了這個問題。樂觀鎖,大多是基於資料版本 version 記錄機制實現。何謂資料版本?即為資料增加乙個版本標識,在基於 資料庫表的版本解決方案中,一般是通過為資料庫表增加乙個 version 欄位來 實現。讀取出資料時,將此版本號一同...

資料庫樂觀鎖

兩個執行緒同時運算元據庫時,希望可以實現,乙個執行緒在修改資料庫的時候,另外乙個執行緒不能對同一條資料進行修改。sql語句 update money set money money 1,version version 1where id and version 測試類 executorservice...

資料庫樂觀鎖

樂觀鎖不是資料庫自帶的,需要我們自己去實現。樂觀鎖是指運算元據庫時 更新操作 想法很樂觀,認為這次的操作不會導致衝突 a使用者操作的時,沒有任何人操作該條記錄 在運算元據時,並不進行任何其他的特殊處理 也就是不加鎖 而在進行更新後,再去判斷是否有衝突了。通常實現是這樣的 在表中的資料進行操作時 更新...