主頁(yè) > 知識(shí)庫(kù) > MySQL鎖的知識(shí)點(diǎn)總結(jié)

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

熱門標(biāo)簽:銷售語(yǔ)音電話機(jī)器人 在哪里申請(qǐng)400電話 外呼系統(tǒng)電銷受騙 400電話申請(qǐng)信用卡 安徽ai電話電銷機(jī)器人有效果嗎 巫師三血與酒地圖標(biāo)注 常州網(wǎng)絡(luò)外呼系統(tǒng)開發(fā) 萊西市地圖標(biāo)注 走過(guò)哪個(gè)省地圖標(biāo)注

鎖的概念

①、鎖,在現(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)前操作的整張表加鎖。它開銷小,加鎖快;不會(huì)出現(xiàn)死鎖;鎖定粒度大,發(fā)生鎖沖突的概率最高,并發(fā)度最低。

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

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

從上述特點(diǎn)可見(jiàn),很難籠統(tǒng)地說(shuō)哪種鎖更好,只能就具體應(yīng)用的特點(diǎn)來(lái)說(shuō)哪種鎖更合適!!僅從鎖的角度 來(lái)說(shuō):表級(jí)鎖更適合于以查詢?yōu)橹鳎挥猩倭堪此饕龡l件更新數(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. 寫鎖(排它鎖):當(dāng)前寫操作沒(méi)有完成前,會(huì)阻斷其他寫鎖和讀鎖。

按粒度分:

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

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

您可能感興趣的文章:
  • 關(guān)于MySQL死鎖問(wèn)題的深入分析
  • MySql 索引、鎖、事務(wù)知識(shí)點(diǎn)小結(jié)
  • mysql共享鎖與排他鎖用法實(shí)例分析
  • MySQL全局鎖和表鎖的深入理解
  • MySQL中的行級(jí)鎖定示例詳解

標(biāo)簽:赤峰 黃石 來(lái)賓 煙臺(tái) 陽(yáng)江 鞍山 果洛 河北

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL鎖的知識(shí)點(diǎn)總結(jié)》,本文關(guān)鍵詞  MySQL,鎖,的,知識(shí)點(diǎn),總結(jié),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL鎖的知識(shí)點(diǎn)總結(jié)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于MySQL鎖的知識(shí)點(diǎn)總結(jié)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章