[mysql]SQL语句性能优化--Groupby中执⾏慢性能差的原因调
查与处理
1. mysql在数据量较⼤的时候、使⽤group by查询结果集时速度很慢的原因可能有以下⼏种:sql update字符串拼接
1) 分组字段不在同⼀张表中
2) 分组字段没有建索引
3)分组字段加DESC后索引没有起作⽤(如何让索引起作⽤才是关键、且听下⽂分解)
4)分组字段中加函数导致索引不起作⽤(这种⼀定要避免、本⽂不对这种情况展开说明)
5)分组字段中含有TEXT或CLOB字段(改成VARCHAR字段)
2.今天讲讲多表关联、但只对⼀表进⾏分组的情况下如何优化
1)优化策略:
先给分组字段建索引
再对该表分组、分组后再和其他表关联查询
2)优化理论:
先利⽤索引将结果集快速最⼩化、然后再和其他表关联鼠标头像图片
mysql面试题sql优化3)优化实例:
原⽂地址:blog.csdn/Tim_phper/article/details/78344444
查看表的⾏数:
优化前SQL:执⾏时间300+秒
SELECT
innovactivelangaugeattack_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
z型檩条大小边加工尺寸`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分析⼀下:labelfor是什么品牌
优化后:300+秒  >>优化到>> 0.28秒