共計(jì) 1218 個字符,預(yù)計(jì)需要花費(fèi) 4 分鐘才能閱讀完成。
丸趣 TV 小編給大家分享一下 MySQL 鎖的知識點(diǎn)有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
鎖的概念
①、鎖,在現(xiàn)實(shí)生活中是為我們想要隱藏于外界所使用的一種工具。
②、在計(jì)算機(jī)中,是協(xié)調(diào)多個進(jìn)程或線程并發(fā)訪問某一資源的一種機(jī)制。
③、在數(shù)據(jù)庫當(dāng)中,除了傳統(tǒng)的計(jì)算資源(CPU、RAM、I/ O 等等)的爭用之外,數(shù)據(jù)也是一種供許多用戶共享訪問的資源。
④、如何保證數(shù)據(jù)并發(fā)訪問的一致性、有效性,是所有數(shù)據(jù)庫必須解決的一個問題。
⑤、鎖的沖突也是影響數(shù)據(jù)庫并發(fā)訪問性能的一個重要因素。
MySQL 鎖的概述
相對于其它數(shù)據(jù)庫而言,MySQL 的鎖機(jī)制比較簡單,其最 顯著的特點(diǎn)是不同的存儲引擎支持不同的鎖機(jī)制。比如,MyISAM 和 MEMORY 存儲引擎采用的是表級鎖(table-level locking)。BDB 存儲引擎采用的是頁面鎖(page-level locking),但也支持表級鎖。InnoDB 存儲引擎既支持行級鎖(row-level locking),也支持表級鎖,但默認(rèn)情況下是采用行級鎖。
表級鎖:表級鎖是 MySQL 中鎖定粒度最大的一種鎖,表示對當(dāng)前操作的整張表加鎖。它開銷小,加鎖快;不會出現(xiàn)死鎖;鎖定粒度大,發(fā)生鎖沖突的概率最高,并發(fā)度最低。
行級鎖:行級鎖是 MySQL 中鎖定粒度最細(xì)的一種鎖,表示只針對當(dāng)前操作的行進(jìn)行加鎖。開銷大,加鎖慢;會出現(xiàn)死鎖;鎖定粒度最小,發(fā)生鎖沖突的概率最低,并發(fā)度也最高。
頁級鎖:頁級鎖是 MySQL 中鎖定粒度介于行級鎖和表級鎖中間的一種鎖。表級鎖速度快,但沖突多。行級沖突少,但速度慢。所以取了折衷的頁級,一次鎖定相鄰的一組記錄。BDB 支持頁級鎖。開銷和加鎖時間界于表鎖和行鎖之間;會出現(xiàn)死鎖;鎖定粒度界于表鎖和行鎖之間,并發(fā)度一般。
從上述特點(diǎn)可見,很難籠統(tǒng)地說哪種鎖更好,只能就具體應(yīng)用的特點(diǎn)來說哪種鎖更合適!!僅從鎖的角度 來說:表級鎖更適合于以查詢?yōu)橹鳎挥猩倭堪此饕龡l件更新數(shù)據(jù)的應(yīng)用,如 Web 應(yīng)用。而行級鎖則更適合于有大量按索引條件并發(fā)更新少量不同數(shù)據(jù),同時又有 并發(fā)查詢的應(yīng)用,如一些在線事務(wù)處理(OLTP)系統(tǒng)。
舉例說明
①、在購買商品時,商品庫存只有 1 個的時候,兩個人同時購買的時候,到底是誰買到的問題。
②、會用到事務(wù),先從庫存表中取出物品的數(shù)據(jù),然后插入訂單,付款后,插入付款表信息。
③、更新商品的數(shù)量,在這個過程中,使用鎖可以對有限的資源進(jìn)行保護(hù),解決隔離和并發(fā)的矛盾。
鎖的分類
按操作分:
讀鎖 (共享鎖):針對同一份數(shù)據(jù),多個讀取操作可以同時進(jìn)行而不互相影響。
寫鎖 (排它鎖):當(dāng)前寫操作沒有完成前,會阻斷其他寫鎖和讀鎖。
按粒度分:
表鎖
行鎖
頁鎖
以上是“MySQL 鎖的知識點(diǎn)有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注丸趣 TV 行業(yè)資訊頻道!