InnoDB索引和MyISAM索引的区别
1 存储结构(主索引/辅助索引)
InnoDB的数据文件本身就是主索引文件。而MyISAM的主索引和数据是分开的。
InnoDB的辅助索引data域存储相应记录主键的值而不是地址。而MyISAM的辅助索引和主索引没有多大区别。
innoDB是聚簇索引,数据挂在逐渐索引之下。
2 锁
MyISAM使用的是表锁 InnoDB使用行锁
3 事务
MyISAM没有事务支持和MVCC
InnoDB支持事务和MVCC
4 主键
MyISAM允许没有任何索引和主键的表存在,索引都是保存行的地址
InnoDB如果没有设定主键或非空唯一索引,就会自动生成一个6字节的主键,数据是主索引的一部分,附加索引保存的是主索引的值
5 外键
MyISAM不支持,InnoDB支持
版权声明:本文为tankfat原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。