辛晨V 2018-11-13 13:53 采纳率: 0%
浏览 1141

MYSQL 查询效率低,设置索引几乎无效

各位大神,帮帮忙

 EXPLAIN SELECT
            x.*
        FROM
            jx_students_score x
        LEFT JOIN jx_student_class z ON x.class_id = z.id
        WHERE
            z.del_flag != '1'
        AND x.del_flag = 0
        GROUP BY
            x.classz,
            x.examination_id

以下是检测和运行的索引
图片说明
![图片说明

  • 写回答

3条回答 默认 最新

  • 「已注销」 2018-11-14 02:31
    关注

    首先,这里又联合,又不等于,又是两个字段分组汇总,怎么可能用到索引。
    group by 要用到索引的条件(1、引用同一索引属性(索引属性 唯一性,稀疏性 ...)2、索引按顺序保存,3、b-tree索引),无论如何都无法满足。
    看数据量很少,才几千而已,可以将语句分步查询,效率会很好。
    第一步分类汇总 classz,examination_id的数据,
    第二步in查询jx_student_class 的信息。那个del_flag 不等于的条件,换成相反的用in查询的条件。
    效率会大幅提升。

    评论

报告相同问题?

悬赏问题

  • ¥15 我想在一个软件里添加一个优惠弹窗,应该怎么写代码
  • ¥15 fluent的在模拟压强时使用希望得到一些建议
  • ¥15 STM32驱动继电器
  • ¥15 Windows server update services
  • ¥15 关于#c语言#的问题:我现在在做一个墨水屏设计,2.9英寸的小屏怎么换4.2英寸大屏
  • ¥15 模糊pid与pid仿真结果几乎一样
  • ¥15 java的GUI的运用
  • ¥15 Web.config连不上数据库
  • ¥15 我想付费需要AKM公司DSP开发资料及相关开发。
  • ¥15 怎么配置广告联盟瀑布流