InnoDB和MyISAM的区别与选择
MyISAM 性能(適合小項目,讀快速)MyISAM 是MySQL中默認的存儲引擎,比如適合新聞系統(tǒng),讀為主。
InnoDB 事務(wù)或外鍵支持(適合大項目,高并發(fā)讀寫)活躍用戶20多萬時候,也能很輕松應(yīng)付;InnoDB 的表需要更多的內(nèi)存和存儲,但是InnoDB自身很多良好的特點,比如事務(wù)支持、存儲 過程、視圖、行級鎖定等等,在并發(fā)很多的情況下,相信InnoDB的表現(xiàn)肯定要比MyISAM強很多。
MyISAM 和InnoDB 如何選擇?
數(shù)據(jù)的大小,是一個影響你選擇什么樣存儲引擎的重要因素,大尺寸的數(shù)據(jù)集趨向于選擇InnoDB方式,因為其支持事務(wù)處理和故障恢復(fù)。數(shù)據(jù)庫的在小 決定了故障恢復(fù)的時間長短,InnoDB可以利用事務(wù)日志進行數(shù)據(jù)恢復(fù),這會比較快。而MyISAM可能會需要幾個小時甚至幾天來干這些事,InnoDB 只需要幾分鐘。
MyISAM類型不支持事務(wù)處理等高級處理,而InnoDB類型支持。MyISAM類型的表強調(diào)的是性能,其執(zhí)行數(shù)度比InnoDB類型更快.兩種類型最主要的差別就是Innodb 支持事務(wù)處理與外鍵和行級鎖.而MyISAM不支持.所以MyISAM往往就容易被人認為只適合在小項目中使用。
我作為使用MySQL的用戶角度出發(fā),Innodb和MyISAM都是比較喜歡的,但是從我目前運維的數(shù)據(jù)庫平臺要達到需求:99.9%的穩(wěn)定性,方便的擴展性和高可用性來說的話,MyISAM絕對是我的首選。當(dāng)然Innodb也不是絕對不用,用事務(wù)的項目如模擬炒股項目,我就是用Innodb的,活躍用戶20多萬時候,也是很輕松應(yīng)付了,因此我個人也是很喜歡Innodb的,只是如果從數(shù)據(jù)庫平臺應(yīng)用出發(fā),我還是會首選MyISAM。
InnoDB和MyISAM的區(qū)別
區(qū)別概述:
MyISAM 是MySQL中默認的存儲引擎,一般來說不是有太多人關(guān)心這個東西。決定使用什么樣的存儲引擎是一個很tricky的事情,但是還是值我們?nèi)パ芯恳幌?#xff0c;這里的文章只考慮 MyISAM 和InnoDB這兩個,因為這兩個是最常見的。
下面先讓我們回答一些問題:
??? 你的數(shù)據(jù)庫有外鍵嗎?用InnoDB
??? 你需要事務(wù)支持嗎?用InnoDB
??? 你需要全文索引嗎?用MyISAM
??? 你的數(shù)據(jù)有多大?大的話用InnoDB,小的話用MyISAM
??? 你經(jīng)常使用什么樣的查詢模式?
COUNT() 在 MyISAM 表中會非常快,而在InnoDB 表下可能會很痛苦;大批的inserts 語句在MyISAM下會快一些,但是updates 在InnoDB 下會更快一些——尤其在并發(fā)量大的時候。
?
思考上面這些問題可以讓你找到合適的方向,但那并不是絕對的。如果你需要事務(wù)處理或是外鍵,那么InnoDB 可能是比較好的方式。如果你需要全文索引,那么通常來說 MyISAM是好的選擇,因為這是系統(tǒng)內(nèi)建的,然而,我們其實并不會經(jīng)常地去測試兩百萬行記錄。所以,就算是慢一點,我們可以通過使用Sphinx從 InnoDB中獲得全文索引。
數(shù)據(jù)的大小,是一個影響你選擇什么樣存儲引擎的重要因素,大尺寸的數(shù)據(jù)集趨向于選擇InnoDB方式,因為其支持事務(wù)處理和故障恢復(fù)。數(shù)據(jù)庫的在小 決定了故障恢復(fù)的時間長短,InnoDB可以利用事務(wù)日志進行數(shù)據(jù)恢復(fù),這會比較快。而MyISAM可能會需要幾個小時甚至幾天來干這些事,InnoDB 只需要幾分鐘。
您操作數(shù)據(jù)庫表的習(xí)慣可能也會是一個對性能影響很大的因素。比如: COUNT() 在 MyISAM 表中會非常快,而在InnoDB 表下可能會很痛苦。而主鍵查詢則在InnoDB下會相當(dāng)相當(dāng)?shù)目?#xff0c;但需要小心的是如果我們的主鍵太長了也會導(dǎo)致性能問題。大批的inserts 語句在MyISAM下會快一些,但是updates 在InnoDB 下會更快一些——尤其在并發(fā)量大的時候。
所以,到底你檢使用哪一個呢?根據(jù)經(jīng)驗來看,如果是一些小型的應(yīng)用或項目,那么MyISAM 也許會更適合。當(dāng)然,在大型的環(huán)境下使用MyISAM 也會有很大成功的時候,但卻不總是這樣的。
如果你正在計劃使用一個超大數(shù)據(jù)量的項目,而且需要事務(wù)處理或外鍵支持,那么你真的應(yīng)該直接使用InnoDB方 式。但需要記住InnoDB 的表需要更多的內(nèi)存和存儲,轉(zhuǎn)換100GB 的MyISAM 表到InnoDB 表可能會讓你有非常壞的體驗。
區(qū)別總結(jié):
1.InnoDB不支持FULLTEXT類型的索引。
2.InnoDB 中不保存表的具體行數(shù),也就是說,執(zhí)行select count(*) from table時,InnoDB要掃描一遍整個表來計算有多少行,但是MyISAM只要簡單的讀出保存好的行數(shù)即可。注意的是,當(dāng)count(*)語句包含 where條件時,兩種表的操作是一樣的。
3.對于AUTO_INCREMENT類型的字段,InnoDB中必須包含只有該字段的索引,但是在MyISAM表中,可以和其他字段一起建立聯(lián)合索引。
4.DELETE FROM table時,InnoDB不會重新建立表,而是一行一行的刪除。
5.LOAD TABLE FROM MASTER操作對InnoDB是不起作用的,解決方法是首先把InnoDB表改成MyISAM表,導(dǎo)入數(shù)據(jù)后再改成InnoDB表,但是對于使用的額外的InnoDB特性(例如外鍵)的表不適用.另外,InnoDB表的行鎖也不是絕對的,如果在執(zhí)行一個SQL語句時MySQL不能確定要掃描的范圍,InnoDB表同樣會鎖全表,例如update table set num=1 where name like “%aaa%”
?
提升InnoDB性能的方法:
MyISAM和InnoDB存儲引擎性能差別并不是很大,針對InnoDB來說,影響性能的主要是 innodb_flush_log_at_trx_commit 這個選項,如果設(shè)置為1的話,那么每次插入數(shù)據(jù)的時候都會自動提交,導(dǎo)致性能急劇下降,應(yīng)該是跟刷新日志有關(guān)系,設(shè)置為0效率能夠看到明顯提升,當(dāng)然,同 樣你可以SQL中提交“SET AUTOCOMMIT = 0”來設(shè)置達到好的性能。另外,還聽說通過設(shè)置innodb_buffer_pool_size能夠提升InnoDB的性能,但是我測試發(fā)現(xiàn)沒有特別明顯 的提升。
基本上我們可以考慮使用InnoDB來替代我們的MyISAM引擎了,因為InnoDB自身很多良好的特點,比如事務(wù)支持、存儲 過程、視圖、行級鎖定等等,在并發(fā)很多的情況下,相信InnoDB的表現(xiàn)肯定要比MyISAM強很多,當(dāng)然,相應(yīng)的在my.cnf中的配置也是比較關(guān)鍵 的,良好的配置,能夠有效的加速你的應(yīng)用。
任何一種表都不是萬能的,只用恰當(dāng)?shù)尼槍I(yè)務(wù)類型來選擇合適的表類型,才能最大的發(fā)揮MySQL的性能優(yōu)勢。
?
問題作業(yè):
1、如何將MyISAM轉(zhuǎn)為InnoDB
2、關(guān)于InnoDB的設(shè)置。
3、使用innodb引擎的一些注意事項。
4、如果一個表中共用兩個引擎,對數(shù)據(jù)庫以后的擴展有或性能有影響嗎?比如,僅對后臺發(fā)布的新聞,前臺以讀為主的表,我設(shè)置為MyISAM引擎。對于商城或會員的一些關(guān)聯(lián)表,要涉及到事務(wù)或高并發(fā)讀寫的,設(shè)置為InnoDB引擎。這樣合理嗎?
?
答案:
這2個引擎的差別還是很大的,從物理結(jié)構(gòu)、索引、事務(wù)、外鍵、緩存、恢復(fù)、備份等方面他們都有一定的差別
可以同時存在,但當(dāng)用到事務(wù)時,myisam的表將無效。 innodb和myisam對同一個sql語句的優(yōu)化是不一樣的。所以不建議混用。innodb對于高負載下的應(yīng)用比較好,經(jīng)常做做備份就行了。
一般不用混合引擎,畢竟差別大了,有些執(zhí)行標準不一樣。
1、如何將MyISAM轉(zhuǎn)為InnoDB
使用ALTER TABLE ... ENGINE=INNODB,或用相同的定義創(chuàng)建一個空InnoDB表,并且用INSERT INTO ... SELECT * FROM ...插入行。建議第二種
2、關(guān)于InnoDB的設(shè)置。根據(jù)個人實際需求
3、使用innodb引擎的一些注意事項。一言難盡,只有遇到時才知道
4、額外的一些話題
我記得在一篇文章說過,為了提高寫的性能,將AUTOCOMMIT設(shè)置為0。我想問一下,如果將AUTOCOMMIT設(shè)置為0,會不會造成其它的不良影響?只不過是取消自動提交而已。 既然需要使用事務(wù),那自然應(yīng)該設(shè)置AUTOCOMMIT為無效。INNODB沒什么不好備份的。定期用 mysqldump 備份,并打開二進制日志即可。
你不敢應(yīng)用innodb的原因不是因為他復(fù)雜? 是因為你不了解他 。了解了innodb的一系列機制以后? 你會果斷放棄myisam。給你的建議就是線上系統(tǒng)不要動? 自己先整體學(xué)習(xí)下mysql 慢慢學(xué)習(xí)innodb 你會發(fā)現(xiàn)innodb能讓你隨心所欲。
?
總結(jié)
以上是生活随笔為你收集整理的InnoDB和MyISAM的区别与选择的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 通过java.util.concurre
- 下一篇: 最长公共子序列(LCS问题)