mysql MyISAM与InnoDB索引的区别

问题1:下面的选项使用了哪些索引(联合索引(c1,c2,c3,c4))
A :where c1=x and c2=x and c4>x and c3=x
B :where c1=x and c2=x and c4=x order by c3
C :where c1=x and c4= x group by c3,c2
D :where c1=x and c5=x order by c2,c3
E :where c1=x and c2=x and c5=? order by c2,c3

问题2:为什么B比A要快上好几个级别(在id,ver上面有联合索引,id是主键索引,user表里面有几个特别长的字段)
A :select id from user order by id;
B :select id from user order by id,ver;
1.图一
索引
图上为innodb的索引图,可以看到的是innodb的主索引为聚簇索引,案例以id为索引,每个索引id下面就存放的是整行的数据(比如:id=3,name=‘李四’,age=6…),比如我要找id=3的用户,只要在索引上找到3,那么就可以直接得到用户的所有数据,次索引比如以name为索引,每个索引下面存放的是用户的主索引id,比如要以name=李四来搜索,他首先经过次索引得到用户的主索引id,然后再通过id去主索引上面找用户的数据(就是所谓的回行)。
注意: innodb来说,
1: 主键索引 既存储索引值,又在叶子中存储行的数据
2: 如果没有主键, 则会Unique key做主键
3: 如果没有unique,则系统生成一个内部的rowid做主键.
4: 像innodb中,主键的索引结构中,既存储了主键值,又存储了行数据,这种结构称为”聚簇索引”

2.图二
MyISAM
图上是MyISAM的索引图,可以看到的是无论是主索引还是次索引,索引下面放的都是数据的地址。
3.好的索引要满足这几点(使用频繁,识别度高,长度小,尽量能够覆盖常用的查询字段)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值