欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL鎖的知識(shí)點(diǎn)總結(jié)

 更新時(shí)間:2019年11月08日 08:14:20   作者:別人放棄我堅(jiān)持吖  
在本篇文章里小編給大家整理了關(guān)于MySQL鎖的知識(shí)點(diǎn)總結(jié)以及實(shí)例內(nèi)容,需要的朋友們學(xué)習(xí)下。

鎖的概念

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

②、在計(jì)算機(jī)中,是協(xié)調(diào)多個(gè)進(jìn)程或線程并發(fā)訪問(wèn)某一資源的一種機(jī)制。

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

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

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

MySQL鎖的概述

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

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

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

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

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

舉例說(shuō)明

①、在購(gòu)買商品時(shí),商品庫(kù)存只有1個(gè)的時(shí)候,兩個(gè)人同時(shí)購(gòu)買的時(shí)候,到底是誰(shuí)買到的問(wèn)題。

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

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

鎖的分類

按操作分:

  1. 讀鎖(共享鎖):針對(duì)同一份數(shù)據(jù),多個(gè)讀取操作可以同時(shí)進(jìn)行而不互相影響。
  2. 寫(xiě)鎖(排它鎖):當(dāng)前寫(xiě)操作沒(méi)有完成前,會(huì)阻斷其他寫(xiě)鎖和讀鎖。

按粒度分:

  1. 表鎖
  2. 行鎖
  3. 頁(yè)鎖

以上就是關(guān)于Mysql鎖的全部相關(guān)知識(shí)點(diǎn),感謝大家的閱讀和對(duì)腳本之家的支持。

相關(guān)文章

  • 解決mysql使用not in 包含null值的問(wèn)題

    解決mysql使用not in 包含null值的問(wèn)題

    這篇文章主要介紹了解決mysql使用not in 包含null值的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • MySQL MHA 運(yùn)行狀態(tài)監(jiān)控介紹

    MySQL MHA 運(yùn)行狀態(tài)監(jiān)控介紹

    這篇文章主要介紹MySQL MHA 運(yùn)行狀態(tài)監(jiān)控,MHA(Master HA)是一款開(kāi)源的 MySQL 的高可用程序,它為 MySQL 主從復(fù)制架構(gòu)提供了 automating master failover 功能,想具體了解的小伙伴可以和小編一起學(xué)習(xí)下面文章內(nèi)容
    2021-10-10
  • MySQL分庫(kù)分表與分區(qū)的入門(mén)指南

    MySQL分庫(kù)分表與分區(qū)的入門(mén)指南

    這篇文章主要給大家介紹了關(guān)于MySQL分庫(kù)分表與分區(qū)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • 簡(jiǎn)述mysql監(jiān)控組復(fù)制

    簡(jiǎn)述mysql監(jiān)控組復(fù)制

    這篇文章主要介紹了mysql監(jiān)控組復(fù)制的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)mysql,感興趣的朋友可以了解下
    2020-08-08
  • 一文了解MySQL事務(wù)隔離級(jí)別

    一文了解MySQL事務(wù)隔離級(jí)別

    這篇文章主要介紹了一文了解MySQL事務(wù)隔離級(jí)別,MySQL?事務(wù)隔離級(jí)別是為了解決并發(fā)事務(wù)互相干擾的問(wèn)題的,文章介紹?4?種事物隔離,需要的小伙伴可以學(xué)習(xí)一下
    2022-07-07
  • MySQL中如何添加新字段

    MySQL中如何添加新字段

    這篇文章主要介紹了MySQL中如何添加新字段方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • MySQL提升大量數(shù)據(jù)查詢效率的優(yōu)化神器

    MySQL提升大量數(shù)據(jù)查詢效率的優(yōu)化神器

    這篇文章主要介紹了MySQL提升大量數(shù)據(jù)查詢效率的優(yōu)化神器,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-07-07
  • MySQL下載安裝配置詳細(xì)教程?附下載資源

    MySQL下載安裝配置詳細(xì)教程?附下載資源

    這篇文章主要介紹了MySQL下載安裝配置詳細(xì)教程?附下載資源,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-09-09
  • MySQL存儲(chǔ)過(guò)程的概念與用法實(shí)例

    MySQL存儲(chǔ)過(guò)程的概念與用法實(shí)例

    我們常用的操作數(shù)據(jù)庫(kù)語(yǔ)言SQL語(yǔ)句在執(zhí)行的時(shí)候需要要先編譯,然后執(zhí)行,而存儲(chǔ)過(guò)程(Stored Procedure)是一組為了完成特定功能的SQL語(yǔ)句集,下面這篇文章主要給大家介紹了關(guān)于MySQL存儲(chǔ)過(guò)程的相關(guān)資料,需要的朋友可以參考下
    2022-02-02
  • 淺談mysql返回Boolean類型的幾種情況

    淺談mysql返回Boolean類型的幾種情況

    這篇文章主要介紹了mysql返回Boolean類型的幾種情況,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06

最新評(píng)論