主頁 > 知識庫 > 簡單了解MySQL存儲引擎

簡單了解MySQL存儲引擎

熱門標(biāo)簽:臨沂做地圖標(biāo)注 新鄉(xiāng)智能外呼系統(tǒng)好處 地圖標(biāo)注客戶付款 申請400電話電話價格 許昌外呼增值業(yè)務(wù)線路 咸陽防封電銷卡 廣東400企業(yè)電話申請流程 石家莊400電話辦理公司 宜賓全自動外呼系統(tǒng)廠家

1. MySql體系結(jié)構(gòu)

在介紹存儲引擎之前先來介紹下MySql的體系結(jié)構(gòu),以便大家知道存儲引擎在MySql整個體系中處于什么位置。下圖是官方提供的一張架構(gòu)圖:

MySQL體系結(jié)構(gòu)圖

從上圖可以發(fā)現(xiàn),MySQL由以下幾部分組成:

  • 連接池組件
  • 管理服務(wù)和工具組件
  • SQL接口組件
  • 查詢分析器組件
  • 優(yōu)化器組件
  • 緩沖(Cache)組件
  • 插件式存儲引擎
  • 物理文件

MySQL數(shù)據(jù)庫區(qū)別于其他數(shù)據(jù)庫的最重要的一個特點就是其插件式的表存儲引擎,從上圖中也可以看到,MySql支持很多種存儲引擎。需要特別注意的是,存儲引擎是基于表的,而不是數(shù)據(jù)庫。

2. MySql存儲引擎

插件式存儲引擎的好處是:能夠根據(jù)具體的應(yīng)用的特點選擇不同的存儲引擎。下面是幾種MySQL常用的存儲引擎。

2.1 InnoDB存儲引擎

InnoDB存儲引擎支持事務(wù),其設(shè)計目標(biāo)主要面向在線事務(wù)處理(OLTP)的應(yīng)用。其特點是行鎖設(shè)計、支持外鍵,并支持類似于Oracle的非鎖定讀,即默認(rèn)讀取操作不會產(chǎn)生鎖。從MySQL數(shù)據(jù)庫5.5.8版本開始,InnoDB存儲引擎是默認(rèn)的存儲引擎。

InnoDB通過使用多版本并發(fā)控制(MVCC)來獲得高并發(fā)性,并且實現(xiàn)了SQL標(biāo)準(zhǔn)的4種隔離級別,默認(rèn)為REPEATABLE級別。同時,使用一種被稱為next-key locking的策略來避免幻讀(phantom)現(xiàn)象的產(chǎn)生。除此之外,InnoDB儲存引擎還提供了插入緩沖(insert buffer)、二次寫(double write)、自適應(yīng)哈希索引(adaptive hash index)、預(yù)讀(read ahead)等高性能和高可用的功能。

對于表中數(shù)據(jù)的存儲,InnoDB存儲引擎采用了聚集(clustered)的方式,因此每張表的存儲都是按主鍵的順序進(jìn)行存放。如果沒有顯式地在表定義時指定主鍵,InnoDB存儲引擎會為每一行生成一個6字節(jié)的ROWID,并以此作為主鍵。

2.2 MyISAM存儲引擎

MyISAM存儲引擎不支持事務(wù)、表鎖設(shè)計,支持全文索引,主要面向一些OLAP數(shù)據(jù)庫應(yīng)用。此外,MyISAM存儲引擎的另一個與眾不同的地方是它的緩沖池只緩存(cache)索引文件,而不緩沖數(shù)據(jù)文件,這點和大多數(shù)的數(shù)據(jù)庫都非常不同。從MySQL 5.0版本開始,MyISAM默認(rèn)支持256TB的單表數(shù)據(jù),這足夠滿足一般應(yīng)用需求。

2.3 Memory存儲引擎

Memory存儲引擎(之前稱HEAP存儲引擎)將表中的數(shù)據(jù)存放在內(nèi)存中,如果數(shù)據(jù)庫重啟或發(fā)生崩潰,表中的數(shù)據(jù)都將消失。它非常適合用于存儲臨時數(shù)據(jù)的臨時表,以及數(shù)據(jù)倉庫中的緯度表。Memory存儲引擎默認(rèn)使用哈希索引,而不是我們熟悉的B+樹索引。

雖然Memory存儲引擎速度非常快,但在使用上還是有一定的限制。比如,只支持表鎖,并發(fā)性能較差,并且不支持TEXT和BLOB列類型。最重要的是,存儲變長字段(varchar)時是按照定常字段(char)的方式進(jìn)行的,因此會浪費內(nèi)存。

此外有一點容易被忽視,MySQL數(shù)據(jù)庫使用Memory存儲引擎作為臨時表來存放查詢的中間結(jié)果集(intermediate result)。如果中間結(jié)果集大于Memory存儲引擎表的容量設(shè)置,又或者中間結(jié)果含有TEXT或BLOB列類型字段,則MySQL數(shù)據(jù)庫會把其轉(zhuǎn)換到MyISAM存儲引擎表而存放到磁盤中。之前提到MyISAM不緩存數(shù)據(jù)文件,因此這時產(chǎn)生的臨時表的性能對于查詢會有損失。

2.4 Archive存儲引擎

Archive存儲引擎只支持INSERT和SELECT操作,從MySQL 5.1開始支持索引。Archive存儲引擎使用zlib算法將數(shù)據(jù)行(row)進(jìn)行壓縮后存儲,壓縮比一般可達(dá)1∶10。正如其名字所示,Archive存儲引擎非常適合存儲歸檔數(shù)據(jù),如日志信息。Archive存儲引擎使用行鎖來實現(xiàn)高并發(fā)的插入操作,但是其本身并不是事務(wù)安全的存儲引擎,其設(shè)計目標(biāo)主要是提供高速的插入和壓縮功能。

當(dāng)然MySql還支持很多其他的存儲引擎,這邊不一一列舉了。

3. 存儲引擎對比整理

存儲引擎可以理解為表的存儲結(jié)構(gòu),每種存儲引擎都支持不同的特性。MySQL支持插件式的存儲引擎,可以為每張數(shù)據(jù)表指定不同的存儲引擎。常用的存儲引擎的特點整體如下:

我們也可以使用下面命令查看當(dāng)前數(shù)據(jù)庫支持哪些存儲引擎:

-- 查看支持的存儲引擎
show engines;

下面對最常用的三種存儲引擎做下簡單總結(jié)介紹:

  • InnoDB:MySQL默認(rèn)的存儲引擎,支持事務(wù)、支持行級鎖和表級鎖、支持各類索引、支持外鍵,高版本的MySQL還支持全文索引,但是批量數(shù)據(jù)插入的效率較低;
  • MyISAM:具有較高的數(shù)據(jù)插入效率和數(shù)據(jù)查詢速度,支持全文索引,但是不支持?jǐn)?shù)據(jù)庫事務(wù),不支持行級鎖,只支持表級鎖;
  • MEMORY:使用這個存儲引擎時,會將表中的數(shù)據(jù)加載到內(nèi)存中,查詢很快,但是對內(nèi)存要求較高。

所以我們應(yīng)該根據(jù)應(yīng)用的具體需求選擇合適的存儲引擎,而不是不加思考的都選擇默認(rèn)存儲引擎(INNODB)。

如果要提供提交、回滾和恢復(fù)的事務(wù)安全(ACID兼容)能力,并要求實現(xiàn)并發(fā)控制,InnoDB是一個很好的選擇。如果數(shù)據(jù)表主要用來插入和查詢記錄,則MyISAM引擎提供較高的處理效率。如果只是臨時存放數(shù)據(jù),數(shù)據(jù)量不大,并且不需要較高的數(shù)據(jù)安全性,可以選擇將數(shù)據(jù)保存在內(nèi)存的MEMORY引擎中,MySQL中使用該引擎作為臨時表,存放查詢的中間結(jié)果。如果只有INSERT和SELECT操作,可以選擇Archive引擎,Archive存儲引擎支持高并發(fā)的插入操作,但是本身并不是事務(wù)安全的。Archive存儲引擎非常適合存儲歸檔數(shù)據(jù),如記錄日志信息可以使用Archive引擎。

4. 參考

《MySQL技術(shù)內(nèi)幕》

以上就是簡單了解MySQL存儲引擎的詳細(xì)內(nèi)容,更多關(guān)于MySQL存儲引擎的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • MySQL Memory 存儲引擎淺析
  • 詳解mysql中的存儲引擎
  • MySQL 選擇合適的存儲引擎
  • 聊聊MySQL中的存儲引擎
  • 簡述MySQL InnoDB存儲引擎
  • MySQL存儲引擎MyISAM與InnoDB區(qū)別總結(jié)整理
  • MySQL InnoDB存儲引擎的深入探秘
  • MySQL常用存儲引擎功能與用法詳解
  • 基于MySQL的存儲引擎與日志說明(全面講解)
  • MySQL存儲引擎總結(jié)
  • MySQL存儲引擎中的MyISAM和InnoDB區(qū)別詳解
  • 關(guān)于MySQL Memory存儲引擎的相關(guān)知識

標(biāo)簽:貴州 鎮(zhèn)江 鷹潭 臺灣 北京 合肥 日照 阜新

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