<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
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        MySQL數據庫事務隔離級別介紹(TransactionIsolationLevel)

        來源:懂視網 責編:小采 時間:2020-11-09 21:03:05
        文檔

        MySQL數據庫事務隔離級別介紹(TransactionIsolationLevel)

        MySQL數據庫事務隔離級別介紹(TransactionIsolationLevel):數據庫隔離級別有四種,應用《高性能mysql》一書中的說明: 然后說說修改事務隔離級別的方法: 1.全局修改,修改mysql.ini配置文件,在最后加上 代碼如下: #可選參數有:READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, S
        推薦度:
        導讀MySQL數據庫事務隔離級別介紹(TransactionIsolationLevel):數據庫隔離級別有四種,應用《高性能mysql》一書中的說明: 然后說說修改事務隔離級別的方法: 1.全局修改,修改mysql.ini配置文件,在最后加上 代碼如下: #可選參數有:READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, S

        數據庫隔離級別有四種,應用《高性能mysql》一書中的說明:

        然后說說修改事務隔離級別的方法:

        1.全局修改,修改mysql.ini配置文件,在最后加上

        代碼如下:
         #可選參數有:READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, SERIALIZABLE.
         [mysqld]
         transaction-isolation = REPEATABLE-READ

        這里全局默認是REPEATABLE-READ,其實MySQL本來默認也是這個級別

        2.對當前session修改,在登錄mysql客戶端后,執行命令:

        要記住mysql有一個autocommit參數,默認是on,他的作用是每一條單獨的查詢都是一個事務,并且自動開始,自動提交(執行完以后就自動結束了,如果你要適用select for update,而不手動調用 start transaction,這個for update的行鎖機制等于沒用,因為行鎖在自動提交后就釋放了),所以事務隔離級別和鎖機制即使你不顯式調用start transaction,這種機制在單獨的一條查詢語句中也是適用的,分析鎖的運作的時候一定要注意這一點

        再來說說鎖機制:
        共享鎖:由讀表操作加上的鎖,加鎖后其他用戶只能獲取該表或行的共享鎖,不能獲取排它鎖,也就是說只能讀不能寫

        排它鎖:由寫表操作加上的鎖,加鎖后其他用戶不能獲取該表或行的任何鎖,典型是mysql事務中

        代碼如下:
        start transaction;
        select * from user where userId = 1 for update;

        執行完這句以后

          1)當其他事務想要獲取共享鎖,比如事務隔離級別為SERIALIZABLE的事務,執行

        代碼如下:
          select * from user;

           將會被掛起,因為SERIALIZABLE的select語句需要獲取共享鎖

          2)當其他事務執行

        代碼如下:
        select * from user where userId = 1 for update;
        update user set userAge = 100 where userId = 1;

        也會被掛起,因為for update會獲取這一行數據的排它鎖,需要等到前一個事務釋放該排它鎖才可以繼續進行

        鎖的范圍:

        行鎖: 對某行記錄加上鎖
        表鎖: 對整個表加上鎖

        這樣組合起來就有,行級共享鎖,表級共享鎖,行級排他鎖,表級排他鎖

        下面來說說不同的事務隔離級別的實例效果,例子使用InnoDB,開啟兩個客戶端A,B,在A中修改事務隔離級別,在B中開啟事務并修改數據,然后在A中的事務查看B的事務修改效果:

        1.READ-UNCOMMITTED(讀取未提交內容)級別

          1)A修改事務級別并開始事務,對user表做一次查詢

           

          2)B更新一條記錄

           

          3)此時B事務還未提交,A在事務內做一次查詢,發現查詢結果已經改變

           

          4)B進行事務回滾

           

          5)A再做一次查詢,查詢結果又變回去了

           

          6)A表對user表數據進行修改

           

          7)B表重新開始事務后,對user表記錄進行修改,修改被掛起,直至超時,但是對另一條數據的修改成功,說明A的修改對user表的數據行加行共享鎖(因為可以使用select)

           

          可以看出READ-UNCOMMITTED隔離級別,當兩個事務同時進行時,即使事務沒有提交,所做的修改也會對事務內的查詢做出影響,這種級別顯然很不安全。但是在表對某行進行修改時,會對該行加上行共享鎖

        2. READ-COMMITTED(讀取提交內容)

          1)設置A的事務隔離級別,并進入事務做一次查詢

           

          2)B開始事務,并對記錄進行修改

           

          3)A再對user表進行查詢,發現記錄沒有受到影響

           

          4)B提交事務

           

          5)A再對user表查詢,發現記錄被修改

           

          6)A對user表進行修改

           

          7)B重新開始事務,并對user表同一條進行修改,發現修改被掛起,直到超時,但對另一條記錄修改,卻是成功,說明A的修改對user表加上了行共享鎖(因為可以select)

           

           

          READ-COMMITTED事務隔離級別,只有在事務提交后,才會對另一個事務產生影響,并且在對表進行修改時,會對表數據行加上行共享鎖

        3. REPEATABLE-READ(可重讀)

          1)A設置事務隔離級別,進入事務后查詢一次

           

          2)B開始事務,并對user表進行修改

           

          3)A查看user表數據,數據未發生改變

           

          4)B提交事務

           

          5)A再進行一次查詢,結果還是沒有變化

           

          6)A提交事務后,再查看結果,結果已經更新

           

          7)A重新開始事務,并對user表進行修改

           

           

          8)B表重新開始事務,并對user表進行修改,修改被掛起,直到超時,對另一條記錄修改卻成功,說明A對表進行修改時加了行共享鎖(可以select)

           

           

          REPEATABLE-READ事務隔離級別,當兩個事務同時進行時,其中一個事務修改數據對另一個事務不會造成影響,即使修改的事務已經提交也不會對另一個事務造成影響。

          在事務中對某條記錄修改,會對記錄加上行共享鎖,直到事務結束才會釋放。

        4.SERIERLIZED(可串行化)

          1)修改A的事務隔離級別,并作一次查詢

           

          2)B對表進行查詢,正常得出結果,可知對user表的查詢是可以進行的

           

          3)B開始事務,并對記錄做修改,因為A事務未提交,所以B的修改處于等待狀態,等待A事務結束,最后超時,說明A在對user表做查詢操作后,對表加上了共享鎖

           

          SERIALIZABLE事務隔離級別最嚴厲,在進行查詢時就會對表或行加上共享鎖,其他事務對該表將只能進行讀操作,而不能進行寫操作。

        您可能感興趣的文章:

      1. MySQL鎖(表鎖,行鎖,共享鎖,排它鎖,間隙鎖)使用詳解
      2. 深入理解Mysql的四種隔離級別
      3. MySQL中Innodb的事務隔離級別和鎖的關系的講解教程
      4. 淺析MYSQL REPEATABLE-READ隔離級別
      5. MySQL 四種事務隔離級別詳解及對比
      6. mysql+Spring數據庫隔離級別與性能分析
      7. MySQL四種事務隔離級別詳解
      8. mysql 詳解隔離級別操作過程(cmd)
      9. MySQL數據庫事務隔離級別詳解
      10. MySQL可重復讀級別能夠解決幻讀嗎
      11. 聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        MySQL數據庫事務隔離級別介紹(TransactionIsolationLevel)

        MySQL數據庫事務隔離級別介紹(TransactionIsolationLevel):數據庫隔離級別有四種,應用《高性能mysql》一書中的說明: 然后說說修改事務隔離級別的方法: 1.全局修改,修改mysql.ini配置文件,在最后加上 代碼如下: #可選參數有:READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, S
        推薦度:
        標簽: 數據庫 mysql 事務
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲天堂在线播放| 久久亚洲精品成人综合| 亚洲色中文字幕在线播放| 6080午夜一级毛片免费看| 亚洲av中文无码乱人伦在线r▽| 中文字幕视频在线免费观看| 亚洲第一区香蕉_国产a| 5555在线播放免费播放| 亚洲欧洲另类春色校园网站| 嫩草影院在线免费观看| 美女裸免费观看网站| 国产精品亚洲αv天堂无码| 久久国产免费直播| 亚洲AV无码一区二区乱子伦| 久久99精品国产免费观看| 亚洲国产av美女网站| 免费爱爱的视频太爽了| 一级日本高清视频免费观看| 亚洲AV永久无码区成人网站 | 亚洲精品无码少妇30P| 永久免费视频v片www| 国产日韩AV免费无码一区二区三区 | 一级毛片免费不卡| 亚洲三级电影网址| 岛国av无码免费无禁网站| 豆国产96在线|亚洲| 亚洲AV无码乱码在线观看富二代| 黄色永久免费网站| 美女被免费网站在线视频免费| 亚洲精品无码鲁网中文电影| 999国内精品永久免费观看| 亚洲国产精品美女久久久久| 亚洲桃色AV无码| 免费电视剧在线观看| 亚洲精品视频免费| 激情亚洲一区国产精品| 亚洲日本一区二区三区在线| 韩国日本好看电影免费看| 无码人妻一区二区三区免费n鬼沢| 亚洲国产精品嫩草影院| 2022年亚洲午夜一区二区福利|