日期:2014-05-16  浏览次数:20947 次

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后面得结果集又不需要过滤 ,所有只用前四个字段就够了