- InnoDB支持事务,MyISAM不支持
- InnoDB 支持外键,而 MyISAM 不支持
- 「InnoDB是聚集索引」,使用B+Tree作为索引结构,数据文件是和索引绑在一起的,必须要有主键。「MyISAM是非聚集索引」,也是使用B+Tree作为索引结构,索引和数据文件是分离的,索引保存的是数据文件的指针。主键索引和辅助索引是独立的。
- 「InnoDB 不保存表的具体行数」。「MyISAM 用一个变量保存了整个表的行数」
- Innodb 有 「redolog」 日志文件,MyISAM 没有
- 「Innodb存储文件有frm、ibd,而Myisam是frm、MYD、MYI」
- Innodb:frm是表定义文件,ibd是数据文件
- Myisam:frm是表定义文件,myd是数据文件,myi是索引文件
- 「InnoDB 支持表、行锁,而 MyISAM 支持表级锁」
- 「InnoDB 必须有唯一索引(主键)」,如果没有指定的话 InnoDB 会自己生成一个隐藏列Row_id来充当默认主键,「MyISAM 可以没有」
- MyISAM只缓存索引,不缓存真实数据,InnoDB不仅缓存索引还要缓存真实数据,对内存要求较高,而且内存大小对性能有决定性的影响
MyISAM 与 InnoDB 的区别是什么?
最新推荐文章于 2024-04-22 23:31:26 发布