mysql中的鎖機制之概念篇

鎖的概念

①、鎖,在現實生活中是爲咱們想要隱藏於外界所使用的一種工具。數據庫

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

③、在數據庫當中,除了傳統的計算資源(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)系統。table

舉例說明

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

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

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

鎖的分類

按操做分:

讀鎖(共享鎖):針對同一份數據,多個讀取操做能夠同時進行而不互相影響。

寫鎖(排它鎖):當前寫操做沒有完成前,會阻斷其餘寫鎖和讀鎖。

按粒度分:

表鎖

行鎖

頁鎖

相關文章
相關標籤/搜索