InnoDB与MyISAM的区别

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