<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ## 數據庫事務并發帶來的問題 >四大問題:更新丟失、臟讀、不可重復讀、幻象讀 假設張三辦了一張招商銀行卡,余額100元,分別說明上述情況。 ### 1、更新丟失 一個事務的更新覆蓋了另一個事務的更新。事務A:向銀行卡存錢100元。事務B:向銀行卡存錢200元。A和B同時讀到銀行卡的余額,分別更新余額,后提交的事務B覆蓋了事務A的更新。更新丟失本質上是寫操作的沖突,解決辦法是一個一個地寫。 ### 2、臟讀 一個事務讀取了另一個事務未提交的數據。事務A:張三妻子給張三轉賬100元。事務B:張三查詢余額。事務A轉賬后(還未提交),事務B查詢多了100元。事務A由于某種問題,比如超時,進行回滾。事務B查詢到的數據是假數據。臟讀本質上是讀寫操作的沖突,解決辦法是寫完之后再讀。 ### 3、不可重復讀 一個事務兩次讀取同一個數據,兩次讀取的數據不一致。事務A:張三妻子給張三轉賬100元。事務B:張三兩次查詢余額。事務B第一次查詢余額,事務A還沒有轉賬,第二次查詢余額,事務A已經轉賬了,導致一個事務中,兩次讀取同一個數據,讀取的數據不一致。不可重復讀本質上是讀寫操作的沖突,解決辦法是讀完再寫。 ### 4、幻象讀 一個事務兩次讀取一個范圍的記錄,兩次讀取的記錄數不一致。事務A:張三妻子兩次查詢張三有幾張銀行卡。事務B:張三新辦一張銀行卡。事務A第一次查詢銀行卡數的時候,張三還沒有新辦銀行卡,第二次查詢銀行卡數的時候,張三已經新辦了一張銀行卡,導致兩次讀取的銀行卡數不一樣。幻象讀本質上是讀寫操作的沖突,解決辦法是讀完再寫。 ### 解決辦法 #### (1)一組事務單元執行加鎖(悲觀鎖) 開啟兩個十五單元之前認為沖突很嚴重,先把鎖加上。兩個事務單元串行。 #### (2)樂觀鎖并發方案 讓版本低的并發更新回滾(事務1比事務2先來,則事務1的版本更低,事務2版本更高) 優點:并發低時性能好 缺點:并發高時失敗率高,需要不斷重試 可以完成并發方案。 ##### 最后結果 事務2完成 事務1在Bob給Smith加100元的更新環節, 檢測到事務1的這一環節的版本號 低于 事務2鎖定smith賬戶數據的版本號, 從而事務回滾。
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看