1、 存儲結構
MyISAM:每個MyISAM在磁盤上存儲成三個文件。第一個文件的名字以表的名字開始,擴展名指出文件類型烈评。.frm文件存儲表定義。數據文件的擴展名為.MYD (MYData)犯建。索引文件的擴展名是.MYI (MYIndex)讲冠。
InnoDB:所有的表都保存在同一個數據文件中(也可能是多個文件,或者是獨立的表空間文件)适瓦,InnoDB表的大小只受限于操作系統文件的大小竿开,一般為2GB。
2玻熙、 存儲空間
MyISAM:可被壓縮否彩,存儲空間較小。支持三種不同的存儲格式:靜態(tài)表(默認揭芍,但是注意數據末尾不能有空格胳搞,會被去掉)、動態(tài)表称杨、壓縮表肌毅。
InnoDB:需要更多的內存和存儲,它會在主內存中建立其專用的緩沖池用于高速緩沖數據和索引姑原。
3悬而、 事務支持
MyISAM:強調的是性能,每次查詢具有原子性,其執(zhí)行數度比InnoDB類型更快锭汛,但是不提供事務支持笨奠。
1)數據塊,INNODB要緩存唤殴,MYISAM只緩存索引塊般婆, 這中間還有換進換出的減少;
2)innodb尋址要映射到塊朵逝,再到行蔚袍,MYISAM記錄的直接是文件的OFFSET,定位比INNODB要快
3)INNODB還需要維護MVCC一致;雖然你的場景沒有啤咽,但他還是需要去檢查和維護
MVCC (Multi-Version Concurrency Control)多版本并發(fā)控制
InnoDB:提供事務支持事務晋辆,外部鍵等高級數據庫功能。 具有事務(commit)宇整、回滾(rollback)和崩潰修復能力(crash recovery capabilities)的事務安全(transaction-safe (ACID compliant))型表瓶佳。
4、 CURD操作
MyISAM:如果執(zhí)行大量的SELECT鳞青,MyISAM是更好的選擇霸饲。(因為沒有支持行級鎖),在增刪的時候需要鎖定整個表格盼玄,效率會低一些贴彼。相關的是innodb支持行級鎖,刪除插入的時候只需要鎖定改行就行埃儿,效率較高
InnoDB:如果你的數據執(zhí)行大量的INSERT或UPDATE器仗,出于性能方面的考慮,應該使用InnoDB表童番。DELETE 從性能上InnoDB更優(yōu)精钮,但DELETE FROM table時,InnoDB不會重新建立表剃斧,而是一行一行的刪除轨香,在innodb上如果要清空保存有大量數據的表,最好使用truncate table這個命令幼东。
5臂容、 外鍵
MyISAM:不支持
InnoDB:支持