本文主要是介绍[mysql]SQL语句性能优化--Group by中执行慢性能差的原因调查与处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
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+秒
SELECTattack_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秒
这篇关于[mysql]SQL语句性能优化--Group by中执行慢性能差的原因调查与处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!