中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL數據庫中有哪些鎖

發布時間:2021-08-31 01:28:18 來源:億速云 閱讀:145 作者:chen 欄目:數據庫

這篇文章主要介紹“MySQL數據庫中有哪些鎖”,在日常操作中,相信很多人在MySQL數據庫中有哪些鎖問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”MySQL數據庫中有哪些鎖”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

在 MySQL 數據庫中,鎖有很多種類型,不過大致可以分為三類:全局鎖、表級鎖、行級鎖。這篇文章我們就簡單的聊一聊這三種鎖。

全局鎖

全局鎖是粒度比較大的鎖,基本上也使用不上,就像我們家的大門一樣,控制著整個數據庫實例。全局鎖就是對整個數據庫實例加鎖,讓整個數據庫處于只讀狀態。

MySQL 提供了一個加全局讀鎖的方法,命令是 Flush tables with read lock  (FTWRL),加鎖之后整個數據庫實例處于只讀狀態,有關數據操作的命令都會被掛起阻塞,例如數據更新語句、數據定義語句、更新類事務語句等等。

所以全局鎖一般只用于全庫備份的時候,一般只用在不支持一致性讀的存儲引擎做全庫備份時,比如 MyISAM  這種不支持一致性讀的存儲引擎做全庫備份時需要使用全局鎖,像 InnoDB 引擎做全庫備份時不需要使用全局鎖。

表級鎖

表級鎖是 MySQL 很基本的鎖策略,并且是開銷最小的策略,它鎖住的不是整個數據庫實例,而是一張表。

表級鎖跟全局鎖一樣,MySQL 數據庫提供了加鎖的命令:lock tables … read/write。例如 lock tables t1 read,  t2 write; 命令,則其他線程寫 t1、讀寫 t2 的語句都會被阻塞。同時,線程 A 在執行 unlock tables 之前,也只能執行讀 t1、讀寫  t2 的操作。連寫 t1 都不允許,自然也不能訪問其他表。

我們可以使用 unlock tables 主動釋放鎖,如果沒有使用的話,在客戶端斷開的時候自動釋放。

表級鎖存在一個問題,如果一個查詢正在遍歷一個表中的數據,而執行期間另一個線程對這個表結構做變更,刪了一列,那么查詢線程拿到的結果跟表結構對不上,肯定是不行的。

為了解決這個問題,MySQL 5.5版本之后引入了元數據鎖(meta data lock,MDL),MDL  是數據庫自動加鎖,當對一個表做增刪改查操作的時候,加 MDL 讀鎖;當要對表做結構變更操作的時候,加 MDL 寫鎖。

MDL 鎖有以下兩個特點:

  • 讀鎖之間不互斥,因此你可以有多個線程同時對一張表增刪改查。

  • 讀寫鎖之間、寫鎖之間是互斥的,用來保證變更表結構操作的安全性。因此,如果有兩個線程要同時給一個表加字段,其中一個要等另一個執行完才能開始執行。

行級鎖

行級鎖顧名思義就是針對數據庫表中的行記錄加鎖,行級鎖可以很大程度的支持并發處理,但是同時也帶來了很大的鎖開銷。

行級鎖比較容易理解,比如事務 A 更新了一行,而這時候事務 B 也要更新同一行,則必須等事務 A 的操作完成后才能進行更新。

行級鎖是由存儲引擎各自實現的,也并不是所有的存儲引擎都支持行級鎖,比如 MyISAM 引擎就不支持行級鎖,這意味著 MyISAM  存儲引擎要控制并發只能使用表級鎖。

InnoDB 引擎實現了行級鎖,InnoDB 存儲引擎中實現了兩種標準的行級鎖:

  • 共享鎖(S Lock):允許事務讀一行

  • 排它鎖(X Lock):允許事務刪除和更新一行

共享鎖是兼容鎖,就是當一個事務已經獲得了行 r 的共享鎖,其他事務可以立即獲得行 r 的共享鎖,因為讀并未改變行 r 的數據。

排他鎖是非兼容鎖,如果有事務想獲取行 r 的排他鎖,若行 r 上有共享鎖或者排它鎖,則它必須等其他事務釋放行 r 的鎖。

在 InnoDB  存儲引擎中,默認情況下使用的是一致性的非鎖定行讀,也就是通過行多版本控制器來讀取行數據,我們可以顯示的為行加上共享鎖和排它鎖,語句如下:

  • SELECT ..... FOR UPDATE:對讀取的行記錄加一個排它鎖,其他事務想要在這些行上加任何鎖都會被阻塞

  • SELECT ....... LOCK IN SHARE  MODE:對讀取的行記錄加一個共享鎖,其他事務可以向被鎖定的記錄加共享鎖,但是想要加排它鎖。則會被阻塞。

到此,關于“MySQL數據庫中有哪些鎖”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

深州市| 随州市| 林周县| 右玉县| 金山区| 东乌珠穆沁旗| 闸北区| 沁源县| 德江县| 会昌县| 周宁县| 扶沟县| 友谊县| 沅江市| 曲水县| 如皋市| 城口县| 昭通市| 新营市| 集贤县| 万山特区| 弥渡县| 浦东新区| 洞头县| 龙陵县| 连州市| 沙坪坝区| 三门峡市| 松潘县| 焦作市| 周宁县| 长岛县| 太保市| 孝昌县| 白山市| 达孜县| 电白县| 旅游| 韶山市| 东乡族自治县| 甘孜县|