首頁  >  文章  >  資料庫  >  MyISAM和InnoDB區別

MyISAM和InnoDB區別

伊谢尔伦
伊谢尔伦原創
2016-12-03 10:58:191319瀏覽

MySQL有多種儲存引擎,MyISAM和InnoDB是其​​中常用的兩種。這裡介紹關於這兩種引擎的一些基本概念(非深入介紹)。

MyISAM是MySQL的預設儲存引擎,基於傳統的ISAM類型,支援全文搜索,但不是事務安全的,而且不支援外鍵。每張MyISAM表存放在三個文件中:frm 文件存放表格定義;資料檔是MYD (MYData);索引文件是MYI (MYIndex)。

InnoDB是事務型引擎,支援回滾、崩潰復原能力、多版本並發控制、ACID事務,支援行級鎖定(InnoDB表的行鎖不是絕對的,如果在執行一個SQL語句時MySQL不能確定要掃描的範圍,InnoDB表同樣會鎖定全表,如like操作時的SQL語句)。 InnoDB儲存它的表和索引在一個表空間中,表空間可以包含數個檔案。

主要區別:

MyISAM是非事務安全型的,而InnoDB是事務安全型的。

MyISAM鎖定的粒度是表級,而InnoDB支援行級鎖定。

MyISAM支援全文類型索引,而InnoDB不支援全文索引。

MyISAM相對簡單,所以在效率上要優於InnoDB,小型應用可以考慮使用MyISAM。

MyISAM表是保存成檔案的形式,在跨平台的資料轉移中使用MyISAM儲存會省去不少的麻煩。

InnoDB表比MyISAM表更安全,可以在保證資料不會遺失的情況下,切換非事務表到事務表(alter table tablename type=innodb)。

應用場景:

MyISAM管理非事務表。它提供高速儲存和檢索,以及全文搜尋能力。如果應用程式中需要執行大量的SELECT查詢,那麼MyISAM是更好的選擇。

InnoDB用於事務處理應用程序,具有眾多特性,包括ACID事務支援。如果應用程式中需要執行大量的INSERT或UPDATE操作,則應該使用InnoDB,這樣可以提高多使用者並發操作的效能。


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn