1. 区别:缓存
(1)事务处理:安全
MyISAM是非事务安全型的,而InnoDB是事务安全型的(支持事务处理等高级处理);并发
(2)锁机制不一样:性能
MyISAM是表级锁,而InnoDB是行级锁;spa
(3)select ,update ,insert ,delete 操做:索引
MyISAM:若是执行大量的SELECT,MyISAM是更好的选择
InnoDB:若是你的数据执行大量的INSERT或UPDATE,出于性能方面的考虑,应该使用InnoDB表
(4)查询表的行数不一样:事务
MyISAM:select count(*) from table,MyISAM只要简单的读出保存好的行数,注意的是,当count(*)语句包含 where条件时,两种表的操做是同样的
InnoDB : InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行
(5)外键支持:
mysiam表不支持外键,而InnoDB支持
2. 为何MyISAM会比Innodb 的查询速度快。io
INNODB在作SELECT的时候,要维护的东西比MYISAM引擎多不少;
1)数据块,INNODB要缓存,MYISAM只缓存索引块, 这中间还有换进换出的减小;
2)innodb寻址要映射到块,再到行,MYISAM 记录的直接是文件的OFFSET,定位比INNODB要快
3)INNODB还须要维护MVCC一致;虽然你的场景没有,但他仍是须要去检查和维护
MVCC ( Multi-Version Concurrency Control )多版本并发控制
3. 应用场景
MyISAM适合:(1)作不少count 的计算;(2)插入不频繁,查询很是频繁;(3)没有事务。innodb
InnoDB适合:(1)可靠性要求比较高,或者要求事务;(2)表更新和查询都至关的频繁,而且行锁定的机会比较大的状况。table