Innodb引擎提供了對資料庫ACID事務的支持,並且實作了SQL標準的四種隔離等級。該引擎還提供了行級鎖定和外鍵約束,它的設計目標是處理大容量資料庫系統,它本身其實就是基於MySQL後台的完整資料庫系統,MySQL運行時Innodb會在記憶體中建立緩衝池,用於緩衝資料和索引。但是此引擎不支援FULLTEXT類型的索引,而且它沒有保存表格的行數,當SELECT COUNT(*) FROM TABLE時需要掃描全表。當需要使用資料庫事務時,該引擎當然是首選。由於鎖定的粒度更小,寫入操作不會鎖定全表,所以在並發較高時,使用Innodb引擎會提升效率。但是使用行級鎖定也不是絕對的,如果在執行一個SQL語句時MySQL不能確定要掃描的範圍,InnoDB表同樣會鎖定全表。
MyIASM是MySQL預設的引擎,但它沒有提供對資料庫事務的支持,也不支援行級鎖定和外鍵,因此當INSERT(插入)或UPDATE(更新)資料時即寫作業需要鎖定整個表,效率便會低一些。不過和Innodb不同,MyIASM中儲存了表格的行數,於是SELECT COUNT(*) FROM TABLE時只需要直接讀取已經保存好的值而不需要進行全表掃描。如果表的讀取操作遠遠多於寫入操作且不需要資料庫事務的支持,那麼MyIASM也是很好的選擇。
1、MyIASM是非事務安全的,而InnoDB是事務安全的
2、MyIASM鎖定的粒度是表級的,而InnoDB支援行級鎖定
3、MyIASM支援全文類型索引,而InnoDB不支援全文索引
4、MyIASM相對簡單,效率上要優於InnoDB,小型應用可以考慮使用MyIASM
5、MyIASM表保存成文件形式,跨平台使用更方便
1、MyIASM管理非事務表,提供高速儲存和檢索以及全文搜尋能力,如果再應用中執行大量select操作,應該選擇MyIASM
2、InnoDB用於事務處理,具有ACID事務支援等特性,如果在應用程式中執行大量insert和update操作,應該選擇InnoDB
以上是MySQL兩種引擎的差別的詳細內容。更多資訊請關注PHP中文網其他相關文章!