qq_41265012 2019-02-08 00:11 采纳率: 70%
浏览 406
已采纳

mysql 简单的查询语句效率问题

为什么走索引还需要消耗8秒,explain检查 这条扫描了30多万条

SELECT * FROM topic where pid=4 and status=1 and id<393203 order by id desc LIMIT 15

只要0.01秒

SELECT * FROM topic where pid=4 and status=1 order by id desc LIMIT 15

只要0.01秒

SELECT * FROM topic where status=1 and id<393203 order by id desc LIMIT 15

为什么where pid=4和id<393203 组合,就变慢了

  • 写回答

3条回答

  • fc6_1 2019-02-20 13:49
    关注

    只能说明 条件 pid=4 的数据量很少;而status=1的数据有30万条以上。加上 判断条件pid=4 的查询语句都变快了

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 虚拟机打包apk出现错误
  • ¥30 最小化遗憾贪心算法上界
  • ¥15 用visual studi code完成html页面
  • ¥15 聚类分析或者python进行数据分析
  • ¥15 逻辑谓词和消解原理的运用
  • ¥15 三菱伺服电机按启动按钮有使能但不动作
  • ¥15 js,页面2返回页面1时定位进入的设备
  • ¥50 导入文件到网吧的电脑并且在重启之后不会被恢复
  • ¥15 (希望可以解决问题)ma和mb文件无法正常打开,打开后是空白,但是有正常内存占用,但可以在打开Maya应用程序后打开场景ma和mb格式。
  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝