久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

      mysql的共享鎖與排他鎖詳解

      mysql鎖機制分為表級鎖和行級鎖,本文就和大家分享一下我對mysql中行級鎖中的共享鎖與排他鎖進行分享交流。

      共享鎖又稱為讀鎖,簡稱S鎖,顧名思義,共享鎖就是多個事務(wù)對于同一數(shù)據(jù)可以共享一把鎖,都能訪問到數(shù)據(jù),但是只能讀不能修改。

      排他鎖又稱為寫鎖,簡稱X鎖,顧名思義,排他鎖就是不能與其他所并存,如一個事務(wù)獲取了一個數(shù)據(jù)行的排他鎖,其他事務(wù)就不能再獲取該行的其他鎖,包括共享鎖和排他鎖,但是獲取排他鎖的事務(wù)是可以對數(shù)據(jù)就行讀取和修改。

      對于共享鎖大家可能很好理解,就是多個事務(wù)只能讀數(shù)據(jù)不能改數(shù)據(jù),對于排他鎖大家的理解可能就有些差別,我當初就犯了一個錯誤,以為排他鎖鎖住一行數(shù)據(jù)后,其他事務(wù)就不能讀取和修改該行數(shù)據(jù),其實不是這樣的。排他鎖指的是一個事務(wù)在一行數(shù)據(jù)加上排他鎖后,其他事務(wù)不能再在其上加其他的鎖。mysql InnoDB引擎默認的修改數(shù)據(jù)語句,update,delete,insert都會自動給涉及到的數(shù)據(jù)加上排他鎖,select語句默認不會加任何鎖類型,如果加排他鎖可以使用select …for update語句,加共享鎖可以使用select … lock in share mode語句。所以加過排他鎖的數(shù)據(jù)行在其他事務(wù)種是不能修改數(shù)據(jù)的,也不能通過for update和lock in share mode鎖的方式查詢數(shù)據(jù),但可以直接通過select …from…查詢數(shù)據(jù),因為普通查詢沒有任何鎖機制。

      說了這么多,咱們來看下以下簡單的例子:

      我們有如下測試數(shù)據(jù)

      mysql的共享鎖與排他鎖詳解

      現(xiàn)在我們對id=1的數(shù)據(jù)行排他查詢,這里會使用begin開啟事務(wù),而不會看見我關(guān)閉事務(wù),這樣做是用來測試,因為提交事務(wù)或回滾事務(wù)就會釋放鎖。

      打開一個查詢窗口

      mysql的共享鎖與排他鎖詳解

      會查詢到一條數(shù)據(jù),現(xiàn)在打開另一個查詢窗口,對同一數(shù)據(jù)分別使用排他查和共享鎖查詢兩種方式查詢

      排他查

      mysql的共享鎖與排他鎖詳解

      共享查

      mysql的共享鎖與排他鎖詳解

      我們看到開了排他鎖查詢和共享鎖查詢都會處于阻塞狀態(tài),因為id=1的數(shù)據(jù)已經(jīng)被加上了排他鎖,此處阻塞是等待排他鎖釋放。

      如果我們直接使用以下查詢呢

      mysql的共享鎖與排他鎖詳解

      我們看到是可以查詢到數(shù)據(jù)的。

      我們再看一下一個事務(wù)獲取了共享鎖,在其他查詢中也只能加共享鎖或不加鎖。

      mysql的共享鎖與排他鎖詳解

      mysql的共享鎖與排他鎖詳解

      mysql的共享鎖與排他鎖詳解

      我們看到是可以查詢數(shù)據(jù)的,但加排他鎖就查不到,因為排他鎖與共享鎖不能存在同一數(shù)據(jù)上。

      最后我們驗證下上面說的mysql InnoDb引擎中update,delete,insert語句自動加排他鎖的問題,

      mysql的共享鎖與排他鎖詳解

      此時共享查詢處于阻塞,等待排它鎖的釋放,但是用普通查詢能查到數(shù)據(jù),因為沒用上鎖機制不與排他鎖互斥,但查到的數(shù)據(jù)是修改數(shù)據(jù)之前的老數(shù)據(jù)。

      mysql的共享鎖與排他鎖詳解

      然后我們提交數(shù)據(jù),釋放排他鎖看下修改后的數(shù)據(jù),此時可用排他查,共享查和普通查詢, 因為事務(wù)提交后該行數(shù)據(jù)釋放排他鎖,下面就只顯示普通查詢,其他的同學(xué)們自己去驗證。

      mysql的共享鎖與排他鎖詳解

      可以看到結(jié)果與預(yù)期的一樣。

      推薦教程:《Mysql教程》

      贊(0)
      分享到: 更多 (0)
      網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號