出现using temporary的原因是因为MySQL在执行查询时需要创建临时表来存储部分结果集,通常是因为查询中包含了ORDER BY或GROUP BY等操作需要对数据进行排序或分组。 要解决这个问题,可以尝试以下几种方式: 优化查询语句:尽量避免在查询中使用不必要的排序和分组操作,可以考虑优化查询条件、创建索引等方式来提高查询性能。 调...
首先查看explain执行计划,让主要查询语句使用索引,索引type级别最好达到ref | ref_eq级别 其次将extra一栏的Using temporary(临时表)、Using filesort(文件排序)拖出去砍了 一、第一条语句 explainselect*fromtb_wm_shopwhereis_delete!=1andis_authentication=1ORDERBYcreate_timeDESC 大家应该知道使用order by的 字...
1. 理解"Using temporary" "Using temporary"是MySQL执行计划中的一个额外信息,表明MySQL在执行查询时需要使用临时表来存储中间结果。这通常发生在复杂的查询操作中,如ORDER BY、GROUP BY、DISTINCT等,当这些操作无法直接通过索引来优化时。 2. 分析查询语句 首先,需要仔细分析查询语句,找出可能导致"Using temporary"的...
发现了错误一:左联接表时,如果orderBy使用的字段是第二张表的字段就会照成Using temporary,修改语句以下是结果 发现结果还是没变,经过确认以上链接的真实性,引出了第二个问题: and p.type = 1 这个导致了查询之后又将p 表 引为了第一张表,导致第一个问题解决之后任然没有生效,就有了以下改动: 现在临时表没有...
MySQL 5.6版本中,对于EXPLAIN INSERT/UPDATE/DELETE功能的加入,使得查询解析过程中能获取执行计划信息。MySQL 5.7版本在EXPLAIN功能上进一步优化,新增了EXPLAIN FOR CONNECTION支持。然而,在使用这些功能时,用户可能会在执行单表UPDATE操作时发现“Using temporary”提示。当查询涉及GROUP BY和ORDER BY子句...
MySQL 5.6 添加了对 EXPLAIN INSERT/UPDATE/DELETE 的支持,在5.7中对 EXPLAIN 代码做了一些改进并且5.7 添加了对 EXPLAIN FOR CONNECTION 的支持,但是在老的版本5.6中对单表的update执行计划会显示使用临时表(Using temporary) 测试环境 CentOS Linux release 7.6.1810 (Core) ...
Using temporary 表示由于排序没有走索引、使用union、子查询连接查询、使用某些视图等原因,因此创建了一个内部临时表。注意这里的临时表可能是内存上的临时表,也有可能是硬盘上的临时表,理所当然基于内存的临时表的时间消耗肯定要比基于硬盘的临时表的实际消耗小。
通过explain查看sql的执行计划时,Extra字段的值往往会看到Using where; Using index; Using temporary; Using filesort 一、using filesort 在使用order by关键字的时候,如果待排序的内容不能由所使用的索引直接完成排序的话,那么mysql有可能就要进行文件排序。
运行上述代码后,我们可以通过查看执行计划来确认是否使用了临时表。如果在执行计划中看到Using Temporary标志,就说明MySQL在处理查询时使用了临时表。 结论 在MySQL中,DISTINCT关键字用于返回不重复的数据行,而Using Temporary标志表示在查询过程中使用了临时表。当我们在查询中使用DISTINCT关键字时,如果MySQL无法直接使用索引...