MySQL兩種存儲引擎區別

Innodb引擎:

Innodb引擎提供了對數據庫ACID事務的支持,並且實現了SQL標準的四種隔離級別。該引擎還提供了行級鎖和外鍵約束,他設計的目的是處理大容量數據庫系統,它本身就是基於MySQL的完整的數據庫系統,MySQL運行時Innodb會在內存中建立緩衝池,用來緩衝數據和索引。Innodb引擎對FULLTEXT索引是MySQL5.6之後新引入的特性(之前只有MyISAM引擎支持FULLTEXT索引),而且他沒有保存表的行數,當SELECT COUNT(*) FROM TABLE時需要掃描全表。當需要使用數據庫事務時,該引擎當然是首選。由於鎖的粒度更小,寫操作不會鎖定全表,所以在併發高時,使用Innodb引擎會提升效率。但是使用行級鎖也不是絕對的,如果在執行一個SQL語句時MySQL不能確定要掃描的範圍,Innodb表同樣會鎖定全表。

MyIASM引擎:

MyIASM引擎是MySQL的默認引擎,但是它沒有對數據庫事務的支持,也不支持行級鎖和外鍵,因此當執行寫操作時需要鎖定整個表,效率便會低一些。不過和Innodb不同,MyIASM中存儲了表的行數,於是SELECT COUNT(*)FROM TABLE 時只需要直接讀取已經保存好的值而不需要全表掃描。如果表的讀操作遠遠多於寫操作且不需要數據庫事物的支持,那麼MyIASM也是很好的選擇。


主要區別:

1、MyIASM是非事務安全的,而InnoDB是事務安全的

2、MyIASM鎖的粒度是表級的,而InnoDB支持行級鎖

3、MyIASM支持全文類型索引,InnoDB不支持全文類型索引

4、MyIASM相對簡單,效率上要優於InnoDB,小型應用可以考慮使用

5、MyIASM表保存成文件形式,快平臺使用更方便


應用場景:

1、MyIASM管理非事務表,提供高速存儲和檢索以及全文搜索能力,如果在應用中執行大量select操作,應該選擇MyIASM

2、InnoDB用於事務處理,具有ACID事務支持等特性,如果在應用中執行大量insert和update操作,應該選擇InnoDB

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章