mysql索引覆盖之innodb和myisam效率问题

问题:

create table A ( 
   id varchar(64) primary key, 
   ver int, 
   ... 

我的表有几个很长的字段varchar(3000) 
在id、ver上有联合索引 

10000条数据 
  
为什么select id from A order by id特别慢,
而select id from A order by id,ver非常快 ?

 

解析:

1.两条sql都使用了索引覆盖。

2.myisam存储引擎,数据行和索引节点分开存放,所以不会存在上述问题。

3.innodb存储引擎,由于数据行和主键索引节点一起存放(聚簇索引),主键索引文件会比较大,

 当只按id排序读取id时,则会遍历主键索引B-TREE去读取id,由于表中的记录行有几个大字段的数据,读取时I/O跳跃会比较大,所以会特别慢;

 而根据符合索引(id,ver)排序查询时,则使用innodb的辅助索引,索引节点只存储了索引数据和主键的地址,而且使用了索引覆盖,只需从索引中读取id即可,所以会非常快。

posted @ 2016-08-10 14:36  lpfuture  阅读(300)  评论(0编辑  收藏  举报