mysql 优化记录

连表优化博文:https://blog.csdn.net/Tim_phper/article/details/78344444?locationNum=9&fps=1
网上搜索得知内联表查询一般的执行过程是:
1、执行FROM语句
2、执行ON过滤
3、添加外部行
4、执行where条件过滤
5、执行group by分组语句
6、执行having
7、select列表
8、执行distinct去重复数据
9、执行order by字句
10、执行limit字句

查找了网上一些博客分析GROUP BY 与临时表的关系 :
  1. 如果GROUP BY 的列没有索引,产生临时表.
  2. 如果GROUP BY时,SELECT的列不止GROUP BY列一个,并且GROUP BY的列不是主键 ,产生临时表.
  3. 如果GROUP BY的列有索引,ORDER BY的列没索引.产生临时表.
  4. 如果GROUP BY的列和ORDER BY的列不一样,即使都有索引也会产生临时表.
  5. 如果GROUP BY或ORDER BY的列不是来自JOIN语句第一个表.会产生临时表.
  6. 如果DISTINCT 和 ORDER BY的列没有索引,产生临时表.

用force index (索引名)来指定索引类型,减少扫描行数

例子,把分组先完成再连表

EXPLAIN SELECT
	*
FROM
	(
		SELECT
			ip,
			sum(attack_count) AS attack_times
		FROM
			blacklist_ip_count_date
		WHERE
			attack_count > 0
		AND date BETWEEN '2018-10-27 00:00:00'
		AND '2018-10-27 23:00:00'
		GROUP BY
			ip
	) A
INNER JOIN blacklist_attack_ip ON blacklist_attack_ip.attack_ip = A.ip

猜你喜欢

转载自blog.csdn.net/w786572258/article/details/83443273