文章目录
- MySQL之临时表
- 1.临时表介绍
- 2.何时产生临时表
MySQL之临时表
1.临时表介绍
*临时表:MySQL 在执行 SQL 语句的过程中 通常会临时创建一些存储中间结果集的表,临时表只对当前连接可见,在连接关闭时,临时表会被删除并释放所有表空间。临时表分为两种:一种是内存临时表,一种是磁盘临时表,什么区别呢?内存临时表使用的是 MEMORY 存储引擎,而临时表采用的是 MylSAM 存储引擎
2.何时产生临时表
MySQL 会在下面这几种情况产生临时表。
(1)使用 UNION 查询:UNION 有两种,一种是 UNION,一种是 UNION ALL,它们都用于联合查询;区别是使用 UNION 会去掉两个表中的重复数据,相当于对结果集做了一下去重(distinct);使用 UNIONALL,则不会排重,返回所有的行。使用 UNION 查询会产生临时表
(2)使用 TEMPTABLE 算法或者是 UNION 查询中的视图。TEMPTABLE 算法是一种创建临时表的算法,它是将结果放置到临时表中,意味这要 MySQL 要先创建好一个临时表,然后将结果放到临时表中去,然后再使用这个临时表进行相应的查询
(3)ORDER BY 和 GROUPBY 的子句不一样时也会产生临时表
(4)DISTINCT 查询并且加上 ORDER BY 时
(5)SQL 中用到 SQL_SMALL_RESULT 选项时;如果查询结果比较小的时候,可以加上 SQL SMALL RESULT 来优化,产生临时表
(6)FROM 中的子查询
(7)EXPLAIN 查看执行计划结果的 Extra 列中,如果使用 Using Temporary 就表示会用到临时表