1. mysql在数据量较大的时候、使用group by查询结果集时速度很慢的原因可能有以下几种:
1) 分组字段不在同一张表中
2) 分组字段没有建索引
3)分组字段加DESC后索引没有起作用(如何让索引起作用才是关键、且听下文分解)
4)分组字段中加函数导致索引不起作用(这种一定要避免、本文不对这种情况展开说明)
5)分组字段中含有TEXT或CLOB字段(改成VARCHAR字段)
2.今天讲讲多表关联、但只对一表进行分组的情况下如何优化
1)优化策略:
先给分组字段建索引
再对该表分组、分组后再和其他表关联查询
2)优化理论:
先利用索引将结果集快速最小化、然后再和其他表关联
3)优化实例:
原文地址:https://blog.csdn.net/Tim_phper/article/details/78344444
查看表的行数:
优化前SQL:执行时间300+秒
SELECT
attack_ip,
country,
province,
city,
line,
info_update_time AS attack_time,
sum( attack_count ) AS attack_times
FROM
`blacklist_attack_ip`
INNER JOIN `blacklist_ip_count_date` ON `blacklist_attack_ip`.`attack_ip` = `blacklist_ip_count_date`.`ip`
WHERE
`attack_count` > 0
AND `date` BETWEEN '2017-10-13 00:00:00'
AND '2017-10-13 23:59:59'
GROUP BY
`ip`
LIMIT 10 OFFSET 1000
先EXPLAIN分析一下:
优化后:300+秒 >>优化到>> 0.28秒