Innodb和Myisam的区别和实现

区别

  1. myisam是默认表类型不是事物安全的;innodb支持事物。

  2. myisam不支持外键;Innodb支持外键。

  3. myisam支持表级锁(不支持高并发,以读为主);innodb支持行锁(共享锁,排它锁,意向锁),粒度更小,但是在执行不能确定扫描范围的sql语句时,innodb同样会锁全表。

  4. 执行大量select,myisam是最好的选择;执行大量的update和insert最好用innodb。

  5. myisam在磁盘上存储上有三个文件.frm(存储表定义)  .myd(存储表数据)  .myi(存储表索引);innodb磁盘上存储的是表空间数据文件和日志文件,innodb表大小只受限于操作系统大小。

  6. myisam使用非聚集索引,索引和数据分开,只缓存索引;innodb使用聚集索引,索引和数据存在一个文件。

  7. myisam保存表具体行数;innodb不保存。

  8. delete from table时,innodb不会重新简历表,而会一行一行的删除。

实现

myisam

Innodb和Myisam的区别和实现_第1张图片

索引由B+树构成,执行查询操作的时候会先搜索B+树,如果找到对应叶子结点会,根据叶子节点的值(地址),拿出整行数据。

Innodb

主索引搜索时

Innodb和Myisam的区别和实现_第2张图片

上图是InnoDB主索引(同时也是数据文件)的示意图,可以看到叶节点包含了完整的数据记录。这种索引叫做聚集索引。因为InnoDB的数据文件本身要按主键聚集,所以InnoDB要求表必须有主键(MyISAM可以没有),如果没有显式指定,则MySQL系统会自动选择一个可以唯一标识数据记录的列作为主键,如果不存在这种列,则MySQL自动为InnoDB表生成一个隐含字段作为主键,这个字段长度为6个字节,类型为长整形。

辅助索引搜索时

Innodb和Myisam的区别和实现_第3张图片

这里以英文字符的ASCII码作为比较准则。聚集索引这种实现方式使得按主键的搜索十分高效,但是辅助索引搜索需要检索两遍索引:首先检索辅助索引获得主键,然后用主键到主索引中检索获得记录。

你可能感兴趣的:(mysql)