mysql两种引擎的适用场景_MySQL两种引擎的区别和应用场景
Innodb引擎
Innodb引擎提供了對數(shù)據(jù)庫ACID事務的支持,并且實現(xiàn)了SQL標準的四種隔離級別。該引擎還提供了行級鎖和外鍵約束,它的設計目標是處理大容量數(shù)據(jù)庫系統(tǒng),它本身其實就是基于MySQL后臺的完整數(shù)據(jù)庫系統(tǒng),MySQL運行時Innodb會在內(nèi)存中建立緩沖池,用于緩沖數(shù)據(jù)和索引。但是該引擎不支持FULLTEXT類型的索引,而且它沒有保存表的行數(shù),當SELECT COUNT(*) FROM TABLE時需要掃描全表。當需要使用數(shù)據(jù)庫事務時,該引擎當然是首選。由于鎖的粒度更小,寫操作不會鎖定全表,所以在并發(fā)較高時,使用Innodb引擎會提升效率。但是使用行級鎖也不是絕對的,如果在執(zhí)行一個SQL語句時MySQL不能確定要掃描的范圍,InnoDB表同樣會鎖全表。
MyIASM引擎
MyIASM是MySQL默認的引擎,但是它沒有提供對數(shù)據(jù)庫事務的支持,也不支持行級鎖和外鍵,因此當INSERT(插入)或UPDATE(更新)數(shù)據(jù)時即寫操作需要鎖定整個表,效率便會低一些。不過和Innodb不同,MyIASM中存儲了表的行數(shù),于是SELECT COUNT(*) FROM TABLE時只需要直接讀取已經(jīng)保存好的值而不需要進行全表掃描。如果表的讀操作遠遠多于寫操作且不需要數(shù)據(jù)庫事務的支持,那么MyIASM也是很好的選擇。
主要區(qū)別:
1、MyIASM是非事務安全的,而InnoDB是事務安全的
2、MyIASM鎖的粒度是表級的,而InnoDB支持行級鎖
3、MyIASM支持全文類型索引,而InnoDB不支持全文索引
4、MyIASM相對簡單,效率上要優(yōu)于InnoDB,小型應用可以考慮使用MyIASM
5、MyIASM表保存成文件形式,跨平臺使用更加方便
應用場景:
1、MyIASM管理非事務表,提供高速存儲和檢索以及全文搜索能力,如果再應用中執(zhí)行大量select操作,應該選擇MyIASM
2、InnoDB用于事務處理,具有ACID事務支持等特性,如果在應用中執(zhí)行大量insert和update操作,應該選擇InnoDB
總結
以上是生活随笔為你收集整理的mysql两种引擎的适用场景_MySQL两种引擎的区别和应用场景的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 控制dcom程序使用端口_使用VS Co
- 下一篇: python实现异步的几种方式_终于搞明