国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

MySQL鎖的知識點總結

2020-01-18 20:39:54
字體:
來源:轉載
供稿:網友

鎖的概念

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

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

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

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

⑤、鎖的沖突也是影響數據庫并發訪問性能的一個重要因素。

MySQL鎖的概述

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

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

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

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

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

舉例說明

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

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

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

鎖的分類

按操作分:

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

按粒度分:

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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 大竹县| 慈溪市| 昌吉市| 教育| 黄骅市| 蓬安县| 龙山县| 苗栗县| 丹阳市| 霍山县| 新密市| 都兰县| 中山市| 安庆市| 上杭县| 天全县| 伊宁市| 苗栗市| 弥渡县| 河南省| 炉霍县| 逊克县| 中卫市| 镇赉县| 庄浪县| 江阴市| 邵东县| 鸡泽县| 固始县| 同心县| 临澧县| 焦作市| 东丽区| 兴海县| 永靖县| 台南市| 昭平县| 班玛县| 大理市| 大理市| 远安县|