order by 中使用索引的问题
msg表有以下列
id 自增长 key
timing int型unixtimestamp
uid 用户id
索引建了2个
Alter table msg ADD INDEX idx1(uid,timing);
Alter table msg ADD INDEX idx2(timing);
当我执行
explain select * from msg where uid =111 order by timing desc 的时候,
期望使用到idx1中的uid,timing 但是结果是只用到了uid 难道order by 不用索引吗?
(为了测试 表中插入了10万行 timing的值也尽量随机分布了)
------解决方案--------------------
key_len 4
使用索引前4个字节就可以定位所有得结果集了
order by后面得结果集又不需要过滤 ,所有只用前四个字段就够了