1. 程式人生 > >mysql樂觀鎖實現

mysql樂觀鎖實現

color new lan 什麽 clas 事務處理 帶來 解決 提交

一、為什麽需要鎖(並發控制)?

在多用戶環境中,在同一時間可能會有多個用戶更新相同的記錄,這會產生沖突。這就是著名的並發性問題。
典型的沖突有:
1.丟失更新:一個事務的更新覆蓋了其它事務的更新結果,就是所謂的更新丟失。例如:用戶A把值從6改為2,用戶B把值從2改為6,則用戶A丟失了他的更新。
2.臟讀:當一個事務讀取其它完成一半事務的記錄時,就會發生臟讀取。例如:用戶A,B看到的值都是6,用戶B把值改為2,用戶A讀到的值仍為6。

為了解決這些並發帶來的問題。 我們需要引入並發控制機制。

二、 並發控制機制

鎖,即給我們選定的目標數據上鎖,使其無法被其他程序修改。

1.悲觀鎖:指的是對數據被外界(包括本系統當前的其他事務,以及來自外部系統的事務處理)修改持保守態度,因此,在整個數據處理過程中,將數據處於鎖定狀態
2.樂觀鎖:假設不會發生並發沖突,只在提交操作時檢查是否違反數據完整性。樂觀鎖不能解決臟讀的問題。

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

1.數據庫表設計

task

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

2.實現

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表時不發生沖突

轉載於:

http://www.cnblogs.com/richerdyoung/p/6427668.html

mysql樂觀鎖實現