<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        Hibernate鎖機制悲觀鎖、樂觀鎖

        來源:懂視網 責編:小采 時間:2020-11-09 14:53:31
        文檔

        Hibernate鎖機制悲觀鎖、樂觀鎖

        Hibernate鎖機制悲觀鎖、樂觀鎖:悲觀鎖 它指的是對數據被外界修改持保守態度。假定任何時刻存取數據時,都可能有另一個客戶也正在存取同一筆數據,為了保持數據被操作的一致性,于是對數據采取了數據庫層次的鎖定狀態,依靠數據庫提供的鎖機制來實現。 基于jdbc實現的數據庫加鎖如下: se
        推薦度:
        導讀Hibernate鎖機制悲觀鎖、樂觀鎖:悲觀鎖 它指的是對數據被外界修改持保守態度。假定任何時刻存取數據時,都可能有另一個客戶也正在存取同一筆數據,為了保持數據被操作的一致性,于是對數據采取了數據庫層次的鎖定狀態,依靠數據庫提供的鎖機制來實現。 基于jdbc實現的數據庫加鎖如下: se

        悲觀鎖 它指的是對數據被外界修改持保守態度。假定任何時刻存取數據時,都可能有另一個客戶也正在存取同一筆數據,為了保持數據被操作的一致性,于是對數據采取了數據庫層次的鎖定狀態,依靠數據庫提供的鎖機制來實現。 基于jdbc實現的數據庫加鎖如下: sele

        悲觀鎖

        它指的是對數據被外界修改持保守態度。假定任何時刻存取數據時,都可能有另一個客戶也正在存取同一筆數據,為了保持數據被操作的一致性,于是對數據采取了數據庫層次的鎖定狀態,依靠數據庫提供的鎖機制來實現。 基于jdbc實現的數據庫加鎖如下:

        select * from account where name="Erica" for update 
        在更新的過程中,數據庫處于加鎖狀態,任何其他的針對本條數據的操作都將被延遲。本次事務提交后解鎖。
        而hibernate悲觀鎖的具體實現如下:
        String sql="查詢語句"; 
        Query query=session.createQuery(sql); 
        query.setLockMode("對象",LockModel.UPGRADE); 
        說到這里,就提到了hibernate的加鎖模式:
        LockMode.NONE:無鎖機制。

        LockMode.WRITE:Hibernate在Insert和Update記錄的時候會自動獲取。

        LockMode.READ:Hibernate在讀取記錄的時候會自動獲取。 這三種加鎖模式是供hibernate內部使用的,與數據庫加鎖無關。

        LockMode.UPGRADE:利用數據庫的for update字句加鎖。 這種模式需要區分前三種模式,該模式是與數據有關的(for update)

        在這里我們要注意的是:只有在查詢開始之前(也就是hiernate生成sql語句之前)加鎖,才會真正通過數據庫的鎖機制加鎖處理。否則,數據已經通過不包含for updata子句的sql語句加載進來,所謂的數據庫加鎖也就無從談起。 但是,從系統的性能上來考慮,對于單機或小系統而言,這并不成問題,然而如果是在網絡上的系統,同時間會有許多聯機,假設有數以百計或上千甚至更多的并發訪問出現,我們該怎么辦?如果等到數據庫解鎖我們再進行下面的操作,我們浪費的資源是多少?--這也就導致了樂觀鎖的產生。

        樂觀鎖

        樂觀鎖定(optimistic locking)則樂觀的認為資料的存取很少發生同時存取的問題,因而不作數據庫層次上的鎖定,為了維護正確的數據,樂觀鎖定采用應用程序上的邏輯實現版本控制的方法。
        例如若有兩個客戶端,A客戶先讀取了賬戶余額100元,之后B客戶也讀取了賬戶余額100元的數據,A客戶提取了50元,對數據庫作了變更,此時數據庫中的余額為50元,B客戶也要提取30元,根據其所取得的資料,100-30將為70余額,若此時再對數據庫進行變更,最后的余額就會不正確。
        在不實行悲觀鎖定策略的情況下,數據不一致的情況一但發生,有幾個解決的方法,一種是先更新為主,一種是后更新的為主,比較復雜的就是檢查發生變動的數據來實現,或是檢查所有屬性來實現樂觀鎖定。
        Hibernate 中透過版本號檢查來實現后更新為主,這也是Hibernate所推薦的方式,在數據庫中加入一個VERSON欄記錄,在讀取數據時連同版本號一同讀取,并在更新數據時遞增版本號,然后比對版本號與數據庫中的版本號,如果大于數據庫中的版本號則予以更新,否則就回報錯誤。
        以剛才的例子,A客戶讀取賬戶余額1000元,并連帶讀取版本號為5的話,B客戶此時也讀取賬號余額1000元,版本號也為5,A客戶在領款后賬戶余額為500,此時將版本號加1,版本號目前為6,而數據庫中版本號為5,所以予以更新,更新數據庫后,數據庫此時余額為500,版本號為6,B客戶領款后要變更數據庫,其版本號為5,但是數據庫的版本號為6,此時不予更新,B客戶數據重新讀取數據庫中新的數據并重新進行業務流程才變更數據庫。
        以Hibernate實現版本號控制鎖定的話,我們的對象中增加一個version屬性,例如:
        public class Account { private int version; .... 
        public void setVersion(int version) { this.version = version; } 
        public int getVersion() { return version; } .... } 
        而在映像文件中,我們使用optimistic-lock屬性設定version控制,屬性欄之后增加一個標簽,如下:
         
          
         ....  
         
        設定好版本控制之后,在上例中如果B 客戶試圖更新數據,將會引發
        StableObjectStateException例外,我們可以捕捉這個例外,在處理中重新讀取數據庫中的數據,同時將 B客戶目前的數據與數據庫中的數據秀出來,讓B客戶有機會比對不一致的數據,以決定要變更的部份,或者您可以設計程式自動讀取新的資料,并重復扣款業務流程,直到數據可以更新為止,這一切可以在背景執行,而不用讓您的客戶知道。
        但是樂觀鎖也有不能解決的問題存在:上面已經提到過樂觀鎖機制的實現往往基于系統中的數據存儲邏輯,在我們的系統中實現,來自外部系統的用戶余額更新不受我們系統的控制,有可能造成非法數據被更新至數據庫。因此我們在做電子商務的時候,一定要小心的注意這項存在的問題,采用比較合理的邏輯驗證,避免數據執行錯誤。

        也可以在使用Session的load()或是lock()時指定鎖定模式以進行鎖定。 如果數據庫不支持所指定的鎖定模式,Hibernate會選擇一個合適的鎖定替換,而不是丟出一個例外。

        未完待續。。

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        Hibernate鎖機制悲觀鎖、樂觀鎖

        Hibernate鎖機制悲觀鎖、樂觀鎖:悲觀鎖 它指的是對數據被外界修改持保守態度。假定任何時刻存取數據時,都可能有另一個客戶也正在存取同一筆數據,為了保持數據被操作的一致性,于是對數據采取了數據庫層次的鎖定狀態,依靠數據庫提供的鎖機制來實現。 基于jdbc實現的數據庫加鎖如下: se
        推薦度:
        標簽: 數據 機制 指的
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲小视频在线观看| 精品国产免费一区二区| 在线亚洲人成电影网站色www| 亚洲日韩一区二区一无码| 成人爽A毛片免费看| 亚洲最大天堂无码精品区| 欧美最猛性xxxxx免费| 亚洲中文无码永久免| 最新69国产成人精品免费视频动漫 | 1000部拍拍拍18勿入免费视频软件| 亚洲第一视频网站| **一级一级毛片免费观看| 亚洲国产精品综合久久久| 成人无码区免费视频观看| 色天使亚洲综合一区二区| 亚洲精品动漫在线| 亚洲成在人线aⅴ免费毛片| 亚洲国产欧美国产综合一区| 亚洲AV无码一区二区三区在线观看| selaoban在线视频免费精品| 日本亚洲欧洲免费天堂午夜看片女人员 | 国产乱码免费卡1卡二卡3卡| 亚洲精品无码不卡在线播放| 美女裸体无遮挡免费视频网站| 亚洲一区二区三区在线播放| 暖暖免费日本在线中文| 久久精品国产亚洲av麻豆蜜芽| 国产精品成人无码免费| 99免费在线视频| 亚洲国产综合第一精品小说| 国产成人精品高清免费| 国色精品va在线观看免费视频| 久久亚洲熟女cc98cm| 国产美女精品视频免费观看| 十八禁视频在线观看免费无码无遮挡骂过| 亚洲国产成人久久精品动漫| 全免费一级午夜毛片| 久久99精品免费一区二区| 亚洲国产成a人v在线| 亚洲精品视频免费观看| xxxxx免费视频|