美文网首页
mysql分析及优化

mysql分析及优化

作者: 路人爱早茶 | 来源:发表于2019-10-28 11:11 被阅读0次

1.临时表生成与groupby

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的列没有索引,产生临时表.

2.表执行步骤


网上搜索得知内联表查询一般的执行过程是:
1、执行FROM语句
2、执行ON过滤
3、添加外部行
4、执行where条件过滤
5、执行group by分组语句
6、执行having
7、select列表
8、执行distinct去重复数据
9、执行order by字句
10、执行limit字句

调优

  • sql中right join表排序不一样会影响查询时间,尽量将结合起来数量少的提前
  • 减少临时表数量


    image.png

    改为


    image.png
    可减少时间(数量级减少)

相关文章

网友评论

      本文标题:mysql分析及优化

      本文链接:https://www.haomeiwen.com/subject/dhlgpctx.html