淺談一下MyISAM和InnoDB存儲(chǔ)引擎的區(qū)別
前言
MyISAM和InnoDB是使用MySQL最常用的兩種存儲(chǔ)引擎,在5.5版本之前默認(rèn)采用MyISAM存儲(chǔ)引擎,從5.5開(kāi)始采用InnoDB存儲(chǔ)引擎。

存儲(chǔ)引擎
存儲(chǔ)引擎是:數(shù)據(jù)庫(kù)管理系統(tǒng)如何存儲(chǔ)數(shù)據(jù)、如何為存儲(chǔ)的數(shù)據(jù)建立索引和如何更新、查詢數(shù)據(jù)等技術(shù)的實(shí)現(xiàn)方法。
MySQL的核心就是插件式存儲(chǔ)引擎,支持多種存儲(chǔ)引擎。
show engines; //查看存儲(chǔ)引擎


關(guān)于數(shù)據(jù)庫(kù)的大致架構(gòu)和基礎(chǔ)操作,這里不過(guò)多介紹;
區(qū)別
說(shuō)區(qū)別之前說(shuō)一下他倆的索引底層都是BTREE+ , B+樹(shù)的數(shù)據(jù)結(jié)構(gòu)維護(hù)索引和數(shù)據(jù)(m是非聚簇索引,i是聚簇索引,這點(diǎn)注意下)
事務(wù)
- InnoDB支持事務(wù),具有安全性和完整性,系統(tǒng)容災(zāi)性強(qiáng),且通過(guò)使用多版本并發(fā)控制MVCC來(lái)獲得高并發(fā)性;
- MyISAM不支持事務(wù); 系統(tǒng)容災(zāi)性弱;
外鍵
- InnoDB支持外鍵
- MyISAM不支持外鍵
因此把一個(gè)有外鍵的InnoDB表單轉(zhuǎn)換成MyISAM表單會(huì)失敗;
表單的存儲(chǔ)
通過(guò)使用不同存儲(chǔ)引擎建立表單查看生成的對(duì)應(yīng)存儲(chǔ)文件,發(fā)現(xiàn)除了雙方共有的 .frm存儲(chǔ)表屬性外:
- InnoDB存儲(chǔ)引擎表單獨(dú)存放到一個(gè)獨(dú)立的IBD文件中;(索引和數(shù)據(jù)放在了一起)–>聚簇索引–>通過(guò)主鍵索引效率高; 普通鍵進(jìn)行索引可能需要回表;
- MyISAM存儲(chǔ)引擎表單由MYD和MYI兩部分組成,其中MYD(MYData)用來(lái)存放數(shù)據(jù)文件,而MYI(MYIndex)則用來(lái)存放索引文件–>非聚簇索引–>數(shù)據(jù)存放的是指針,不需要回表,主鍵索引和普通鍵索引分開(kāi)了;
數(shù)據(jù)查詢效率
- InnoDB不支持全文索引,而 MyISAM 支持全文索引,查詢效率上 MyISAM更高;
- InnoDB不保存表的具體行數(shù),執(zhí)行 select count(*) from table 時(shí)需要全表掃描。而 MyISAM 用一個(gè)變量保存了整個(gè)表的行數(shù),執(zhí)行上述語(yǔ)句時(shí)只需要讀出該變量即可,速度很快;
數(shù)據(jù)更新效率
InnoDB的內(nèi)部?jī)?yōu)化,包括**磁盤預(yù)讀(**從磁盤讀取數(shù)據(jù)時(shí)采用可預(yù)測(cè)性讀取),自適應(yīng)哈希(自動(dòng)在內(nèi)存中創(chuàng)建hash索引以加速讀操作)等, 且能夠加速插入操作的插入緩沖區(qū)。所以比MyISAM在數(shù)據(jù)更新能力上更優(yōu);
如何選擇
- 看設(shè)計(jì)的業(yè)務(wù)是否需要支持事務(wù),需要–InnoDB;不需要–MyISAM;
- 如果select讀操作頻繁,用MyISAM; 如果數(shù)據(jù)更新操作使用頻繁操作用InnoDB;
- 考慮系統(tǒng)容災(zāi)能力,MyISAM更不容易恢復(fù),InnoDB容易恢復(fù);
既然MySQL5.5版本之后默認(rèn)了InnoDB,不知道用什么那就InnoDB,跟著主流走不會(huì)錯(cuò);
到此這篇關(guān)于淺談一下MyISAM和InnoDB存儲(chǔ)引擎的區(qū)別的文章就介紹到這了,更多相關(guān)MyISAM和InnoDB存儲(chǔ)引擎內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL與PHP的基礎(chǔ)與應(yīng)用專題之?dāng)?shù)據(jù)查詢
MySQL是一個(gè)關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),由瑞典MySQL?AB?公司開(kāi)發(fā),屬于?Oracle?旗下產(chǎn)品。MySQL?是最流行的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng)之一,本系列將帶你掌握php與mysql的基礎(chǔ)應(yīng)用,本篇從數(shù)據(jù)的查詢開(kāi)始2022-02-02
MySQL備份時(shí)排除指定數(shù)據(jù)庫(kù)的方法
這篇文章主要介紹了MySQL備份時(shí)排除指定數(shù)據(jù)庫(kù)的方法的相關(guān)資料,需要的朋友可以參考下2016-03-03
MySQL存儲(chǔ)過(guò)程中使用WHILE循環(huán)語(yǔ)句的方法
這篇文章主要介紹了MySQL存儲(chǔ)過(guò)程中使用WHILE循環(huán)語(yǔ)句的方法,實(shí)例分析了在MySQL中循環(huán)語(yǔ)句的使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07
mysql嚴(yán)格模式Strict?Mode詳細(xì)說(shuō)明
使用mysql嚴(yán)格模式可以使數(shù)據(jù)更加安全嚴(yán)格,缺點(diǎn)是減少了對(duì)空數(shù)據(jù)入庫(kù)的兼容性,下面這篇文章主要給大家介紹了關(guān)于mysql嚴(yán)格模式Strict?Mode詳細(xì)說(shuō)明的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08
MySQLexplain之possible_keys、key及key_len詳解
這篇文章主要介紹了MySQLexplain之possible_keys、key及key_len的用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08

