佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > MySQL鎖的知識點總結

MySQL鎖的知識點總結

熱門標簽:地方門戶網站 Linux服務器 百度競價排名 鐵路電話系統(tǒng) 呼叫中心市場需求 網站排名優(yōu)化 服務外包 AI電銷

鎖的概念

①、鎖,在現(xiàn)實生活中是為我們想要隱藏于外界所使用的一種工具。

②、在計算機中,是協(xié)調多個進程或線程并發(fā)訪問某一資源的一種機制。

③、在數(shù)據(jù)庫當中,除了傳統(tǒng)的計算資源(CPU、RAM、I/O等等)的爭用之外,數(shù)據(jù)也是一種供許多用戶共享訪問的資源。

④、如何保證數(shù)據(jù)并發(fā)訪問的一致性、有效性,是所有數(shù)據(jù)庫必須解決的一個問題。

⑤、鎖的沖突也是影響數(shù)據(jù)庫并發(fā)訪問性能的一個重要因素。

MySQL鎖的概述

相對于其它數(shù)據(jù)庫而言,MySQL的鎖機制比較簡單,其最 顯著的特點是不同的存儲引擎支持不同的鎖機制。比如,MyISAM和MEMORY存儲引擎采用的是表級鎖(table-level locking)。BDB存儲引擎采用的是頁面鎖(page-level locking),但也支持表級鎖。InnoDB存儲引擎既支持行級鎖(row-level locking),也支持表級鎖,但默認情況下是采用行級鎖。

表級鎖:表級鎖是MySQL中鎖定粒度最大的一種鎖,表示對當前操作的整張表加鎖。它開銷小,加鎖快;不會出現(xiàn)死鎖;鎖定粒度大,發(fā)生鎖沖突的概率最高,并發(fā)度最低。

行級鎖:行級鎖是MySQL中鎖定粒度最細的一種鎖,表示只針對當前操作的行進行加鎖。開銷大,加鎖慢;會出現(xiàn)死鎖;鎖定粒度最小,發(fā)生鎖沖突的概率最低,并發(fā)度也最高。

頁級鎖:頁級鎖是MySQL中鎖定粒度介于行級鎖和表級鎖中間的一種鎖。表級鎖速度快,但沖突多。行級沖突少,但速度慢。所以取了折衷的頁級,一次鎖定相鄰的一組記錄。BDB支持頁級鎖。開銷和加鎖時間界于表鎖和行鎖之間;會出現(xiàn)死鎖;鎖定粒度界于表鎖和行鎖之間,并發(fā)度一般。

從上述特點可見,很難籠統(tǒng)地說哪種鎖更好,只能就具體應用的特點來說哪種鎖更合適??!僅從鎖的角度 來說:表級鎖更適合于以查詢?yōu)橹?,只有少量按索引條件更新數(shù)據(jù)的應用,如Web應用。而行級鎖則更適合于有大量按索引條件并發(fā)更新少量不同數(shù)據(jù),同時又有 并發(fā)查詢的應用,如一些在線事務處理(OLTP)系統(tǒng)。

舉例說明

①、在購買商品時,商品庫存只有1個的時候,兩個人同時購買的時候,到底是誰買到的問題。

②、會用到事務,先從庫存表中取出物品的數(shù)據(jù),然后插入訂單,付款后,插入付款表信息。

③、更新商品的數(shù)量,在這個過程中,使用鎖可以對有限的資源進行保護,解決隔離和并發(fā)的矛盾。

鎖的分類

按操作分:

  1. 讀鎖(共享鎖):針對同一份數(shù)據(jù),多個讀取操作可以同時進行而不互相影響。
  2. 寫鎖(排它鎖):當前寫操作沒有完成前,會阻斷其他寫鎖和讀鎖。

按粒度分:

  1. 表鎖
  2. 行鎖
  3. 頁鎖

以上就是關于Mysql鎖的全部相關知識點,感謝大家的閱讀和對腳本之家的支持。

您可能感興趣的文章:
  • 關于MySQL死鎖問題的深入分析
  • MySql 索引、鎖、事務知識點小結
  • mysql共享鎖與排他鎖用法實例分析
  • MySQL全局鎖和表鎖的深入理解
  • MySQL中的行級鎖定示例詳解

標簽:崇左 衡水 銅川 黃山 仙桃 湖南 蘭州 湘潭

巨人網絡通訊聲明:本文標題《MySQL鎖的知識點總結》,本文關鍵詞  ;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    南投县| 颍上县| 荃湾区| 汝南县| 江津市| 阿坝县| 南充市| 桂东县| 五莲县| 莫力| 千阳县| 绥宁县| 本溪| 施秉县| 辽宁省| 晴隆县| 托克逊县| 石首市| 哈密市| 扎鲁特旗| 清新县| 汝城县| 高台县| 安塞县| 盐城市| 开化县| 泸西县| 太保市| 嘉黎县| 浠水县| 青神县| 临沂市| 潜山县| 桃园县| 会理县| 垫江县| 达拉特旗| 临西县| 福安市| 松潘县| 洱源县|