MySQL什么时候会使用内部临时表?
1.union执行过程
首先我们创建一个表t1
- create table t1(id int primary key, a int, b int, index(a));
- delimiter ;;
- create procedure idata()
- begin
- declare i int;
- set i=1;
- while(i<=1000)do
- insert into t1 values(i, i, i);
- set i=i+1;
- end while;
- end;;
- delimiter ;
- call idata();
然后我们执行一下这条语句
- explain select 1000 as f union (select id from t1 order by id desc limit 2)
首先说下union的语义,union的语义是取两个结果的并集,重复的保留一行,然后我们来看下explain的结果,第二行的key=PRIMARY,说明用到了主键索引。
第三行的Extra的Using temporary说明用到了临时表
下面我们看下这条语句的执行流程:
1.创建一个临时表,只有f一个字段,且为主键
2.将1000这个数据插入临时表
3.子查询中步骤:
1.插入1000进入临时表,因为主键冲突,插入失败
2.插入第二行900,插入成功
4.将临时表数据作为结果返回,并删除临时表
这个过程的流程图如下:
如果我们把union改成union all,就不需要使用临时表了,因为union all是重复的也保留,
大家可以看到extra这一列已经没有了Using temporary
- explain select 1000 as f union all (select id from t1 order by id desc limit 2)
2.group by执行过程
我们来看下面这条语句:
- explain select id%10 as m, count(*) as c from t1 group by m;
可以看到explain结果
Using index(使用到了覆盖索引a,不需要回表); Using temporary(用到了临时表); Using filesort(对数据进行了排序)
这条语句的意思是将id%10进行分组统计,并按照m进行排序
执行流程如下:
1.创建临时表,增加m,c字段,m是主键
2.计算id%10的结果记为x
3.如果临时表里面没有主键为x的行,则插入(x,1),如果有的话,就将该行的c值加1
4.遍历完成后,按照m字段排序返回结果给客户端
流程图如下
接下来我们看下这条语句的执行结果
- explain select id%10 as m, count(*) as c from t1 group by m
其实,如果我们不需要对查询结果进行排序,我们可以加一个order by null
我们执行一下这条语句
- explain select id%10 as m, count(*) as c from t1 group by m order by null
可以看到这里没有进行排序,由于扫描是从表t的id是从1开始的,所以第一行是1
如果我们执行下列语句,会发生什么呢?
我们上面说的临时表,其实是内存临时表,如果我们把内存临时表的容量改的比我们要查询的数据的容量小,那么就会使用到磁盘临时表,磁盘临时表的默认引擎是innodb
- et tmp_table_size=1024;
- select id%100 as m, count(*) as c from t1 group by m order by null limit 10
group by 优化方法--直接排序
其实在上面的关于从内存临时表转化成磁盘临时表是很浪费时间的,也就是说mysql,在执行过程中发现空间不够了,在转成磁盘临时表,但是如果我们直接告诉mysql,我要查询的数据很大,那么mysql优化器就会想到,既然你告诉我数据很大,那么我就直接用sort_buffer进行排序,如果sort_buffer内存不够大,会用到磁盘临时表辅助排序。
- select SQL_BIG_RESULT id%100 as m, count(*) as c from t1 group by m;
小结一下:
1.如果我们不需要对统计结果进行排序,可以加上order by null省去排序流程。
2.尽量让排序过程用上内存临时表,可以通过适当调大tmp_table_size的值来避免用到磁盘临时表。
3.如果数据量实在太大,使用SQL_BIG_RESULT告诉优化器,直接使用排序算法。
MySQL什么时候会使用内部临时表?的更多相关文章
- MySQL · 特性分析 · 内部临时表
http://mysql.taobao.org/monthly/2016/06/07/#rd MySQL中的两种临时表 外部临时表 通过CREATE TEMPORARY TABLE 创建的临时表,这种 ...
- MySQL -- 内部临时表
本文转载自MySQL -- 内部临时表 UNION UNION语义:取两个子查询结果的并集,重复的行只保留一行 表初始化 CREATE TABLE t1(id INT PRIMARY KEY, a I ...
- MySQL安装出现“不是内部或外部命令,也不是可执行程序”等一系列问题的解决方案
MySQL安装出现“不是内部或外部命令,也不是可执行程序” 一.这是应该是环境变量处问题了,设置如下: 1)右击我的电脑选择“属性”,找到“高级系统设置” 2)在系统属性下,选择“高级”中的“环境变量 ...
- Mysql学习笔记(十一)临时表+视图
学习内容: 临时表和视图的基本操作... 临时表与视图的使用范围... 1.临时表 临时表:临时表,想必大家都知道这个概念的存在...但是我们什么时候应该使用到临时表呢?当一个数据库存在着大量的数 ...
- MySQL如何删除#sql开头的临时表
1. 现象 巡检时发现服务器磁盘空间不足,通过查看大文件进行筛选是发现有几个#sql开头的文件,且存在超过100G及10G以上的文件. 2. 原因 如果MySQL在一个 ALTER TABLE操作( ...
- mysql优化: 内存表和临时表
由于直接使用临时表来创建中间表,其速度不如人意,因而就有了把临时表建成内存表的想法.但内存表和临时表的区别且并不熟悉,需要查找资料了.一开始以为临时表是创建后存在,当连接断开时临时表就会被删除,即临时 ...
- mysql安装后不是内部或外部命令解决
在环境变量中配置mysql的bin 怎么找到bin目录,在管理工具,服务,常规选项卡下找到 双击mysql后,常规选项卡下的路径就是bin的路径,然后把该路径配置到环境变量中,即可,然后net sta ...
- IIS+PHP+Mysql 返回500,服务器内部资源问题
这个错误困扰了我好久.... 尝试了好多方法都不管用,最后突然发现我的代码是: <?php $link=mysql_connect("localhost","xxx ...
- mysql 分组查询的结果当成临时表 在求最大值
select avg(data1) as a from temp WHERE YEAR(mdate)= 2018 and MONTH(mdate)=03 and day(mdate)=25 GROUP ...
随机推荐
- tomcat假死现象(转)
1.1 编写目的 为了方便大家以后发现进程假死的时候能够正常的分析并且第一时间保留现场快照. 1.2编写背景 最近服务器发现tomcat的应用会偶尔出现无法访问的情况.经过一段时间的观察最近又发现有台 ...
- Bootstrap历练实例:导航中的表单
Bootstrap历练实例:导航中的表单,它是使用class.navbar-form类,这确保了表单适当的垂直对齐和在较窄的视口中折叠的行为,使用这个对齐方式选项来决定导航栏中的内容放置在哪里. 实例 ...
- html中注释的问题
在修改jsp页面的时候遇到了一个有点难懂的注释,mark一下 <script> <!-- alert("js code"); //--> </scri ...
- DateFormat的format()方法线程不安全的问题分析
最近看到<侦探剧场:堆内存神秘溢出事件>https://my.oschina.net/u/2368090/blog/1628720,于是自己也想测试了解一下DateFormat的多线程安全 ...
- axure笔记--内部框架交互链接
内部框架的作用: 1.可以引用站点地图的页面 2.可以引用视频(链接视频)(axure中没有媒体控件) 3.可以引用本地文件 4.引用网页(注意:1.超链接地址要加上http:// 2.内部框架大 ...
- tensorboard以时间命名每一个文件夹
tensorboard 有一个良好的命名习惯以时间命名每一个文件夹,例如**20190523_081232** ''' from datetiome import datetime dir = os. ...
- Python基础知识-day2
格式化输出 %占位符,s字符串,d 数字, 表示% 用%% name = input("请输入姓名: ") age = input("请输入年龄: ") he ...
- 自定义View画一条线
#import "PublishContextView.h" @implementation PublishContextView -(void)drawRect:(CGRect) ...
- LeetCode(109) Convert Sorted List to Binary Search Tree
题目 Given a singly linked list where elements are sorted in ascending order, convert it to a height b ...
- vm下-kali-linux-xfce-2018.1的简略安装
1.选择版本为 debian 系统,因为是kali是基于debian的linux发行版 2.在安装首页选择 Graphical install,图形化安装,之后会让选择语言,选择简体中文,中国等,这些 ...