溫馨提示×

溫馨提示×

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

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

mysql的鎖機制是什么

發布時間:2021-03-05 10:17:54 來源:億速云 閱讀:197 作者:小新 欄目:編程語言

小編給大家分享一下mysql的鎖機制是什么,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

MySQL鎖的概述

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

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

免費學習視頻教程分享:mysql視頻教程

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

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

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

舉例說明

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

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

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

鎖的分類

按操作分:

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

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

按粒度分:

表鎖、行鎖、頁鎖

以上是“mysql的鎖機制是什么”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

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

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女