37 | 什么时候会使用内部临时表?

本文介绍了在MySQL中,`union`和`group by`操作如何使用内部临时表,详细解析了执行流程。对于`union`,当存在去重需求时,会使用内存临时表进行数据整合;而`group by`操作则在分组统计时创建临时表。同时,文章探讨了`group by`的优化方法,包括利用索引和使用`SQL_BIG_RESULT`提示来改善性能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

union 执行流程

(select 1000 as f) union (select id from t1 order by id desc limit 2);

在这里插入图片描述
key=PRIMARY,说明第二个子句用到了索引 id。 Extra 字段,表示在对子查询的结果集做 union 的时候,使用了临时表 (Using temporary)。

执行流程
  1. 创建一个内存临时表,这个临时表只有一个整型字段 f,并且 f 是主键字段。
  2. 执行第一个子查询,得到 1000 这个值,并存入临时
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值