- InnoDB支持事务,MyISAM不支持,对于InnoDB每一条SQL语言都默认封装成事务,自动提交,这样会影响速度,所以最好把多条SQL语言放在begin和commit之间,组成一个事务;
- InnoDB支持外键,而MyISAM不支持。对一个包含外键的InnoDB表转为MYISAM会失败;
- InnoDB是聚集索引,使用B+Tree作为索引结构,数据文件是和(主键)索引绑在一起的(表数据文件本身就是按B+Tree组织的一个索引结构),必须要有主键,通过主键索引效率很高。但是辅助索引需要两次查询,先查询到主键,然后再通过主键查询到数据。因此,主键不应该过大,因为主键太大,其他索引也都会很大。
- MyISAM 可以被压缩后进行查询操作
- MyISAM 支持表级锁,InnoDB支持表,行锁。
- InnoDB 不支持全文索引,而 MyISAM 支持全文索引,5.7 以后InnoDB 支持全文索引。
- InnoDB 必须有主键,MyISAM 可以没有。
InnoDB与MyISAM的区别
-------------本文结束感谢您的阅读-------------