通过explain查看sql的执行计划时,Extra字段的值往往会看到Using where; Using index; Using temporary; Using filesort 一、using filesort 在使用order by关键字的时候,如果待排序的内容不能由所使用的索引直接完成排序的话,那么mysql有可能就要进行文件排序。 【这个 filesort 并不是说通过磁盘文件进行排序,而只是告...
通过explain查看sql的执行计划时,Extra字段的值往往会看到Using where; Using index; Using temporary; Using filesort,其中此次重点关注Using temporary; Using filesort。Using temporaryUsing temporary表示由于排序没有走索引、使用union、子查询连接查询、使用某些视图等原因(详见internal-temporary-tables),因此创建了一...
从上面的解释上来看,filesort和temporary的使用场景的区别并不是很明显,不过,有以下的原则: filesort只能应用在单个表上,如果有多个表的数据需要排序,那么MySQL会先使用using temporary保存临时数据,然后再在临时表上使用filesort进行排序,最后输出结果。 参考:数据库内核月报 1.What does Using filesort mean in MySQL?
结合你的问题,EXPLAIN 输出显示:Using temporary; Using filesort,这意味着使用了临时表和文件排序,需要回表。因此,该查询存在回表操作。
另外在5.6之前的版本,如果涉及到多表关联查询,排序字段来自不同表的话,会将关联结果保存到临时表中,这就是我们平时看到using temporary;using filesort的场景,如果这时候再使用limit,limit将会发生在排序之后,这样也可能导致排序的数据量非常大。 整个情况来看,缓冲区大小、排序字段的数据长度、查询数据条数等都会影响...
Mysql-explain之Usingtemporary和Usingfilesort解决⽅案 项⽬刚刚告⼀段落,boos⼜让优化⼏个主要界⾯ 程序代码⽅便的优化就不讲了,主要说MySQL的优化 ⾸先查看explain执⾏计划,让主要查询语句使⽤索引,索引type级别最好达到ref | ref_eq级别 其次将extra⼀栏的Using temporary(临时表)、Using ...
使用了Using temporary Using filesort,这个涉及到这两个的含义: Using temporary 表示由于排序没有走索引、使用union、子查询连接查询、使用某些视图等原因,因此创建了一个内部临时表。注意这里的临时表可能是内存上的临时表,也有可能是硬盘上的临时表,理所当然基于内存的临时表的时间消耗肯定要比基于硬盘的临时表的实...
在MySQL的EXPLAIN输出中,using where、using filesort和using temporary是常见的Extra信息,它们提供了关于查询执行过程中MySQL是如何处理数据的洞察。下面是对这些术语的解释、可能的影响以及优化建议。 1. using where在MySQL EXPLAIN输出中的含义 解释: using where表示MySQL服务器在处理查询时,使用了WHERE子句来过滤行。
要优化这个SQL查询,尤其是避免Using temporary和Using filesort,可以考虑以下几种方法: 索引优化: 确保在连接和过滤条件上使用了合适的索引。 对于ORDER BY和GROUP BY字段,考虑创建覆盖索引。 查询重写: 使用子查询或CTE(公用表表达式)来预先计算数量,从而避免在GROUP BY和ORDER BY中直接使用聚合函数。 以下是优化后...
这样我们发现,不会再有Using temporary了,而且在查询jos_content时,查询的记录明显有了数量级的降低,这是因为jos_content的idx_catid起了作用。 所以结论是: 尽量对第一个表的索引键进行排序,这样效率是高的。 我们还会发现,在排序的语句中都出现了Using filesort,字面意思可能会被理解为:使用文件进行排序或中文件...