標籤:mysql 資料庫 引擎
1、 儲存結構
MyISAM:每個MyISAM在磁碟上儲存成三個檔案。第一個檔案的名字以表的名字開始,副檔名指出檔案類型。.frm檔案儲存體表定義。資料檔案的副檔名為.MYD (MYData)。索引檔案的副檔名是.MYI (MYIndex)。
InnoDB:所有的表都儲存在同一個資料檔案中(也可能是多個檔案,或者是獨立的資料表空間檔案),InnoDB表的大小隻受限於作業系統檔案的大小,一般為2GB。
2、 儲存空間
MyISAM:可被壓縮,儲存空間較小。支援三種不同的儲存格式:靜態表(預設,但是注意資料末尾不能有空格,會被去掉)、動態表、壓縮表。
InnoDB:需要更多的記憶體和儲存,它會在主記憶體中建立其專用的緩衝池用於高速緩衝資料和索引。
3、 事務支援
MyISAM:強調的是效能,每次查詢具有原子性,其執行數度比InnoDB類型更快,但是不提供事務支援。
InnoDB:提供事務支援事務,外部鍵等進階資料庫功能。 具有事務(commit)、復原(rollback)和崩潰修複能力(crash recovery capabilities)的事務安全(transaction-safe (ACID compliant))型表。
4、 CURD操作
MyISAM:如果執行大量的SELECT,MyISAM是更好的選擇。(因為沒有支援行級鎖),在增刪的時候需要鎖定整個表格,效率會低一些。相關的是innodb支援行級鎖,刪除插入的時候只需要鎖定改行就行,效率較高
InnoDB:如果你的資料執行大量的INSERT或UPDATE,出於效能方面的考慮,應該使用InnoDB表。DELETE 從效能上InnoDB更優,但DELETE FROM table時,InnoDB不會重建立立表,而是一行一行的刪除,在innodb上如果要清空儲存有大量資料的表,最好使用truncate table這個命令。
5、 外鍵
MyISAM:不支援
InnoDB:支援
本文出自 “小屁孩兒” 部落格,請務必保留此出處http://865516915.blog.51cto.com/9037379/1904642
mysql資料庫引擎 MyISAM和 InnoDB區別