淺談選擇mysql存儲(chǔ)引擎的標(biāo)準(zhǔn)
主要存儲(chǔ)引擎的介紹
1、InnoDB存儲(chǔ)引擎
InnoDB是MySQL的默認(rèn)事務(wù)型引擎,它被設(shè)計(jì)用來處理大量的短期(short-lived)事務(wù)。除非有非常特別的原因需要使用其他的存儲(chǔ)引擎,否則應(yīng)該優(yōu)先考慮InnoDB引擎。
建議使用MySQL5.5及以后的版本,因?yàn)檫@個(gè)版本及以后的版本的InnoDB引擎性能更好。
MySQL4.1以后的版本中,InnoDB可以將每個(gè)表的數(shù)據(jù)和索引存放在單獨(dú)的文件中。這樣在復(fù)制備份崩潰恢復(fù)等操作中有明顯優(yōu)勢(shì)??梢酝ㄟ^在my.cnf中增加innodb_file_per_table來開啟這個(gè)功能。如下:
InnoDB采用MVCC來支持高并發(fā),并且實(shí)現(xiàn)了四個(gè)標(biāo)準(zhǔn)的隔離級(jí)別。其默認(rèn)級(jí)別是REPEATABLE READ(可重復(fù)讀),并且通過間隙鎖(next-key locking)策略防止幻讀的出現(xiàn)。(事務(wù)和事務(wù)隔離級(jí)別是另一個(gè)大題目,各自網(wǎng)補(bǔ)吧)。
InnoDB是基于聚簇索引建立的,聚簇索引對(duì)主鍵查詢有很高的性能。不過它的二級(jí)索引(secondary index,非主鍵索引)中必須包含主鍵列,所以如果主鍵列很大的話,其他的所有索引都會(huì)很大。因此表上的索引較多的話,主鍵應(yīng)當(dāng)盡可能的小。
InnoDB的存儲(chǔ)格式是平臺(tái)獨(dú)立的,可以將數(shù)據(jù)和索引文件從Intel平臺(tái)復(fù)制到Sun SPARC平臺(tái)或其他平臺(tái)。
InnoDB通過一些機(jī)制和工具支持真正的熱備份,MySQL的其他存儲(chǔ)引擎不支持熱備份。
2、MyISAM存儲(chǔ)引擎
MyISAM提供了大量的特性,包括全文索引、壓縮、空間函數(shù)(GIS)等,但MyISAM不支持事務(wù)和行級(jí)鎖,有一個(gè)毫無疑問的缺陷就是崩潰后無法安全恢復(fù)。
MyISAM會(huì)將表存儲(chǔ)在兩個(gè)文件在中:數(shù)據(jù)文件和索引文件,分別是.MYD和.MYI為擴(kuò)展名。
在MySQL5.0以前,只能處理4G的數(shù)據(jù),5.0中可以處理256T的數(shù)據(jù)。
在數(shù)據(jù)不再進(jìn)行修改操作時(shí),可以對(duì)MyISAM表進(jìn)行壓縮,壓縮后可以提高讀能力,原因是減少了磁盤I/O。
3、Archive引擎
Archive存儲(chǔ)引擎只支持INSERT和SELECT操作,在MySQL5.1之前不支持索引。
Archive表適合日志和數(shù)據(jù)采集類應(yīng)用。
Archive引擎支持行級(jí)鎖和專用的緩存區(qū),所以可以實(shí)現(xiàn)高并發(fā)的插入,但它不是一個(gè)事物型的引擎,而是一個(gè)針對(duì)高速插入和壓縮做了優(yōu)化的簡(jiǎn)單引擎。
幾個(gè)常用存儲(chǔ)引擎的特點(diǎn)
下面我們重點(diǎn)介紹幾種常用的存儲(chǔ)引擎并對(duì)比各個(gè)存儲(chǔ)引擎之間的區(qū)別和推薦使用方式。
最常使用的2種存儲(chǔ)引擎:
Myisam是Mysql的默認(rèn)存儲(chǔ)引擎。當(dāng)create創(chuàng)建新表時(shí),未指定新表的存儲(chǔ)引擎時(shí),默認(rèn)使用Myisam。每個(gè)MyISAM在磁盤上存儲(chǔ)成三個(gè)文件。文件名都和表名相同,擴(kuò)展名分別是.frm(存儲(chǔ)表定義)、.MYD (MYData,存儲(chǔ)數(shù)據(jù))、.MYI (MYIndex,存儲(chǔ)索引)。數(shù)據(jù)文件和索引文件可以放置在不同的目錄,平均分布io,獲得更快的速度。
InnoDB存儲(chǔ)引擎提供了具有提交、回滾和崩潰恢復(fù)能力的事務(wù)安全。但是對(duì)比Myisam的存儲(chǔ)引擎,InnoDB寫的處理效率差一些并且會(huì)占用更多的磁盤空間以保留數(shù)據(jù)和索引。
如何選擇合適的存儲(chǔ)引擎
選擇標(biāo)準(zhǔn):根據(jù)應(yīng)用特點(diǎn)選擇合適的存儲(chǔ)引擎,對(duì)于復(fù)雜的應(yīng)用系統(tǒng)可以根據(jù)實(shí)際情況選擇多種存儲(chǔ)引擎進(jìn)行組合。
下面是常用存儲(chǔ)引擎的適用環(huán)境:
MyISAM:默認(rèn)的MySQL插件式存儲(chǔ)引擎,它是在Web、數(shù)據(jù)倉(cāng)儲(chǔ)和其他應(yīng)用環(huán)境下最常使用的存儲(chǔ)引擎之一
InnoDB:用于事務(wù)處理應(yīng)用程序,具有眾多特性,包括ACID事務(wù)支持。
Memory:將所有數(shù)據(jù)保存在RAM中,在需要快速查找引用和其他類似數(shù)據(jù)的環(huán)境下,可提供極快的訪問。
Merge:允許MySQL DBA或開發(fā)人員將一系列等同的MyISAM表以邏輯方式組合在一起,并作為1個(gè)對(duì)象引用它們。對(duì)于諸如數(shù)據(jù)倉(cāng)儲(chǔ)等VLDB環(huán)境十分適合。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
MySQL中LIKE?BINARY和LIKE模糊查詢實(shí)例代碼
通常在實(shí)際應(yīng)用中,會(huì)涉及到模糊查詢的需求,下面這篇文章主要給大家介紹了關(guān)于MySQL中LIKE?BINARY和LIKE模糊查詢的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11淺析刪除表的幾種方法(delete、drop、truncate)
這篇文章主要介紹了刪除表的幾種方法,需要的朋友可以參考下2014-05-05mysql 8.0.15 版本安裝教程 連接Navicat.list
這篇文章主要為大家詳細(xì)介紹了mysql 8.0.15 版本安裝教程,連接Navicat.list,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08mysql中刪除數(shù)據(jù)的幾種方法(最新推薦)
在MySQL數(shù)據(jù)庫(kù)中,刪除數(shù)據(jù)是一個(gè)常見的操作,它允許從表中移除不再需要的數(shù)據(jù),在執(zhí)行刪除操作時(shí),需要謹(jǐn)慎,以免誤刪重要數(shù)據(jù),本文給大家介紹mysql中刪除數(shù)據(jù)的幾種方法,感興趣的朋友一起看看吧2023-11-11K8s中MySQL?數(shù)據(jù)持久化存儲(chǔ)的實(shí)現(xiàn)
本文主要介紹了K8s中MySQL?數(shù)據(jù)持久化存儲(chǔ)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01一步步教你在Navicat上如何停止正在運(yùn)行的MYSQL語(yǔ)句
很多時(shí)候我們會(huì)提交一些耗時(shí)比較長(zhǎng)的sql,可能出現(xiàn)mysql服務(wù)器內(nèi)存或者CPU暴增,引起報(bào)警,甚至影響其他業(yè)務(wù),下面這篇文章主要給大家介紹了關(guān)于在Navicat上如何停止正在運(yùn)行的MYSQL語(yǔ)句的相關(guān)資料,需要的朋友可以參考下2023-03-03