mysql樂觀鎖實現

來源:互聯網
上載者:User

標籤:悲觀鎖   http   數字   成功   tle   衝突   包括   並發   帶來   

      在多使用者環境中,在同一時間可能會有多個使用者更新相同的記錄,這會產生衝突。這就是著名的並發性問題。
      典型的衝突有:
        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樂觀鎖實現

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.