order by 中使用索引的问题
时间:2011-12-16
来源:互联网
             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的值也尽量随机分布了)
            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的值也尽量随机分布了)
作者: nindeping4 发布时间: 2011-12-16
             explain的结果肯定是使用了索引,而且是idx1,而不是idx2。
结果确实只用到了uid,然后根据timing来进行排序,这个是没问题的。
LZ可以把explain的结果贴出来。
            结果确实只用到了uid,然后根据timing来进行排序,这个是没问题的。
LZ可以把explain的结果贴出来。
作者: DenielJean 发布时间: 2011-12-16
  引用 1 楼 denieljean 的回复:
  
explain的结果肯定是使用了索引,而且是idx1,而不是idx2。
结果确实只用到了uid,然后根据timing来进行排序,这个是没问题的。
LZ可以把explain的结果贴出来。
explain的结果肯定是使用了索引,而且是idx1,而不是idx2。
结果确实只用到了uid,然后根据timing来进行排序,这个是没问题的。
LZ可以把explain的结果贴出来。
为什么会没有用到timing呢 explain的结果就是用idx1 但只有uid的四个字节
作者: nindeping4 发布时间: 2011-12-16
 相关阅读 更多  
      
    热门阅读
-  
 office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
          阅读:74
 -  
 如何安装mysql8.0
          阅读:31
 -  
 Word快速设置标题样式步骤详解
          阅读:28
 -  
 20+道必知必会的Vue面试题(附答案解析)
          阅读:37
 -  
 HTML如何制作表单
          阅读:22
 -  
 百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
          阅读:31
 -  
 ET文件格式和XLS格式文件之间如何转化?
          阅读:24
 -  
 react和vue的区别及优缺点是什么
          阅读:121
 -  
 支付宝人脸识别如何关闭?
          阅读:21
 -  
 腾讯微云怎么修改照片或视频备份路径?
          阅读:28
 















