MySQL 存儲(chǔ)引擎

1. 存儲(chǔ)引擎相關(guān)介紹

存儲(chǔ)引擎在 MySQL 的體系架構(gòu)中位于第三層,負(fù)責(zé) MySQL 中的數(shù)據(jù)的存儲(chǔ)和提取聚谁,是與文件打交道的子系統(tǒng)搪搏,它是根據(jù) MySQL 提供的文件訪問層抽象接口定制的一種文件訪問機(jī)制馍乙,這種機(jī)制就叫作存儲(chǔ)引擎。

 -- 查看當(dāng)前數(shù)據(jù)庫支持的引擎信息
show engines; 

在5.5 版本之前默認(rèn)采用 MyISAM 存儲(chǔ)引擎执虹,從5.5開始采用 InnoDB 存儲(chǔ)引擎。

  • Memory:利用內(nèi)存創(chuàng)建表蒋畜,訪問速度非成罚快,因?yàn)閿?shù)據(jù)在內(nèi)存姻成,而且默認(rèn)使用 Hash索引插龄,但是一旦關(guān)閉,數(shù)據(jù)就會(huì)丟失科展。
  • MRG_MyISAM:一組 MyISAM 表的組合均牢,這些 MyISAM 表必須結(jié)構(gòu)相同,Merge 表本身沒有數(shù)據(jù)才睹, 對 Merge 操作可以對一組 MyISAM 表進(jìn)行操作徘跪。
  • CSV:以 CSV 文件進(jìn)行數(shù)據(jù)存儲(chǔ),由于文件限制琅攘,所有列必須強(qiáng)制指定 not null垮庐,另外CSV引擎也不 支持索引和分區(qū),適合做數(shù)據(jù)交換的中間表坞琴。
  • Federated:可以訪問遠(yuǎn)端 MySQL 數(shù)據(jù)庫中的表哨查。一個(gè)本地表,不保存數(shù)據(jù)剧辐,訪問遠(yuǎn)程表內(nèi)容寒亥。
  • MyISAM:不支持事務(wù)和外鍵邮府,訪問速度快。
  • InnoDB:支持事務(wù)溉奕,具有提交褂傀,回滾和崩潰恢復(fù)能力,事務(wù)安全加勤。
  • BlackHole: 黑洞仙辟,只進(jìn)不出,進(jìn)來消失鳄梅,所有插入數(shù)據(jù)都不會(huì)保存欺嗤。
  • Archive:歸檔類型引擎,僅能支持 insertselect 語句卫枝。

2. InnoDB 和 MyISAM 對比

InnoDBMyISAM 是使用 MySQL 是常用的兩種引擎類型

2.1 事務(wù)和外鍵

  • InnoDB 支持事務(wù)和外鍵煎饼,具有安全性和完整性,適合大量 insertupdate 操作
  • MyISAM 不支持事務(wù)和外鍵校赤,它提供高速存儲(chǔ)和檢索吆玖,適合大量的 select 查詢操作

2.2 鎖機(jī)制

  • InnoDB 支持行級(jí)鎖,鎖定指定記錄马篮≌闯耍基于索引來加鎖實(shí)現(xiàn)。
  • MyISAM 支持表級(jí)鎖浑测,鎖定整張表翅阵。

2.3 索引結(jié)構(gòu)

  • InnoDB 使用聚集索引(聚簇索引),索引和記錄在一起存儲(chǔ)迁央,既緩存索引掷匠,也緩存記錄。
  • MyISAM 使用非聚集索引(非聚簇索引)岖圈,索引和記錄分開讹语。

2.4 并發(fā)處理能力

  • MyISAM 使用表鎖,會(huì)導(dǎo)致寫操作并發(fā)率低蜂科,讀之間并不阻塞顽决,讀寫阻塞。
  • InnoDB 讀寫阻塞可以與隔離級(jí)別有關(guān)导匣,可以采用多版本并發(fā)控制(MVCC)來支持高并發(fā)

2.5 存儲(chǔ)文件

  • InnoDB 表對應(yīng)兩個(gè)文件才菠,一個(gè) .frm 表結(jié)構(gòu)文件,一個(gè) .ibd 數(shù)據(jù)文件贡定。InnoDB 表大支持 64TB赋访;
  • MyISAM 表對應(yīng)三個(gè)文件,一個(gè) .frm 表結(jié)構(gòu)文件,一個(gè) MYD 表數(shù)據(jù)文件进每,一個(gè) .MYI索引文件。從 MySQL5.0 開始默認(rèn)限制是 256TB命斧。

2.6 適用場景

2.6.1 MyISAM
  • 不需要事務(wù)支持(不支持)
  • 并發(fā)相對較低(鎖定機(jī)制問題)
  • 數(shù)據(jù)修改相對較少田晚,以讀為主
  • 數(shù)據(jù)一致性要求不高
2.6.2 InnoDB
  • 需要事務(wù)支持(具有較好的事務(wù)特性)
  • 行級(jí)鎖定對高并發(fā)有很好的適應(yīng)能力
  • 數(shù)據(jù)更新較為頻繁的場景
  • 數(shù)據(jù)一致性要求較高
  • 硬件設(shè)備內(nèi)存較大,可以利用 InnoDB 較好的緩存能力來提高內(nèi)存利用率国葬,減少磁盤 IO
2.6.3 總結(jié)

兩種引擎該如何選擇贤徒?
是否需要事務(wù)?有汇四,InnoDB
是否存在并發(fā)修改接奈?有,InnoDB
是否追求快速查詢通孽,且數(shù)據(jù)修改少序宦?是,MyISAM
在絕大多數(shù)情況下背苦,推薦使用 InnoDB

3. 擴(kuò)展資料:各個(gè)存儲(chǔ)引擎特性對比

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末互捌,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子行剂,更是在濱河造成了極大的恐慌秕噪,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,386評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件厚宰,死亡現(xiàn)場離奇詭異腌巾,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)铲觉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門澈蝙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人撵幽,你說我怎么就攤上這事碉克。” “怎么了并齐?”我有些...
    開封第一講書人閱讀 164,704評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵漏麦,是天一觀的道長。 經(jīng)常有香客問我况褪,道長撕贞,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,702評(píng)論 1 294
  • 正文 為了忘掉前任测垛,我火速辦了婚禮捏膨,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己号涯,他們只是感情好目胡,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著链快,像睡著了一般誉己。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上域蜗,一...
    開封第一講書人閱讀 51,573評(píng)論 1 305
  • 那天巨双,我揣著相機(jī)與錄音,去河邊找鬼霉祸。 笑死筑累,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的丝蹭。 我是一名探鬼主播慢宗,決...
    沈念sama閱讀 40,314評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼奔穿!你這毒婦竟也來了婆廊?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,230評(píng)論 0 276
  • 序言:老撾萬榮一對情侶失蹤巫橄,失蹤者是張志新(化名)和其女友劉穎淘邻,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體湘换,經(jīng)...
    沈念sama閱讀 45,680評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡宾舅,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了彩倚。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片筹我。...
    茶點(diǎn)故事閱讀 39,991評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖帆离,靈堂內(nèi)的尸體忽然破棺而出蔬蕊,到底是詐尸還是另有隱情,我是刑警寧澤哥谷,帶...
    沈念sama閱讀 35,706評(píng)論 5 346
  • 正文 年R本政府宣布岸夯,位于F島的核電站,受9級(jí)特大地震影響们妥,放射性物質(zhì)發(fā)生泄漏猜扮。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評(píng)論 3 330
  • 文/蒙蒙 一监婶、第九天 我趴在偏房一處隱蔽的房頂上張望旅赢。 院中可真熱鬧齿桃,春花似錦、人聲如沸煮盼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽僵控。三九已至香到,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間喉祭,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評(píng)論 1 270
  • 我被黑心中介騙來泰國打工雷绢, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留泛烙,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,158評(píng)論 3 370
  • 正文 我出身青樓翘紊,卻偏偏與公主長得像蔽氨,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子帆疟,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容