很搞笑的在打麻将 2021-12-01 10:10 采纳率: 33.3%
浏览 34

mysql子查询索引失效问题

问题遇到的现象和发生背景

查询主表然后在里面进行排序,然后在作为结果进行子查询进行group by 以及 order by

问题相关代码,请勿粘贴截图
EXPLAIN SELECT * FROM (
          SELECT t1.*
         FROM leave_record_pre t1 
         ORDER BY t1.create_time DESC
     ) t
GROUP BY t.mark_id
       , t.`pre_audit_status`
ORDER BY t.pre_audit_status ASC
       , t.create_time DESC
;
运行结果及报错内容

运行用时3秒多

id  select_type  table       type    possible_keys  key     key_len  ref       rows  Extra         
               
 1  PRIMARY      <derived2>  ALL     (NULL)         (NULL)  (NULL)   (NULL)  265471  Using temporary; Using filesort  
 2  DERIVED      t1          ALL     (NULL)         (NULL)  (NULL)   (NULL)  265471  Using filesort                   
我的解答思路和尝试过的方法
我想要达到的结果

1秒内查询结果

  • 写回答

1条回答 默认 最新

  • hou1988426 2021-12-01 15:04
    关注

    我的建议 是 子查询不放 ORDER BY t1.create_time DESC 排序 这个没必要 因为 t1 整理查询的数据 都要GROUP BY 结果集进行分组,所以 会浪费查询时间!另外据我了解 索引的使用场景 应该在 where 上 你这也没用上 所以索引 没应用上!

    评论 编辑记录

报告相同问题?

问题事件

  • 修改了问题 12月1日
  • 创建了问题 12月1日

悬赏问题

  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)