一条sql语句引发mysql不停创建临时表的问题解决..coping to tmp table on desk

Posted zishengY

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一条sql语句引发mysql不停创建临时表的问题解决..coping to tmp table on desk相关的知识,希望对你有一定的参考价值。

(不懂临时表的先看 MySQL临时表 )
首先,临时表只在当前连接可见,当关闭连接时,mysql会自动删除表并释放所有空间。因此在不同的连接中可以创建同名的临时表,并且操作属于本连接的临时表。
        创建临时表的语法与创建表语法类似,不同之处是增加关键字TEMPORARY
       临时表主要用于对大数据量的表上作一个子集,提高查询效率。但是当语句写得有问题则可能会造成不断的创建的临时表,导致磁盘I/O利用率过高。
我之前写了一个存储过程,里面有一条语句,刚开始用了group by ..having,如下
用explain分析该语句可知,该语句会使用临时表(Using temprory),
执行语句后,用SHOW GLOBAL STATUS LIKE \'Created_tmp_disk_tables\';和
SHOW GLOBAL STATUS LIKE \'Created_tmp_tables\';查看,发现临时表一直在增加
当去掉group by..having再用explain分析,可知,不会再Using temrory

 

 
 
 
参考文章:

以上是关于一条sql语句引发mysql不停创建临时表的问题解决..coping to tmp table on desk的主要内容,如果未能解决你的问题,请参考以下文章

sql如何创建临时表

c# sql临时表的创建和查询问题。

SQL如何把查询出来的多个表创建成一个临时表

MySQL创建临时表?

SQL如何把查询出来的多个表创建成一个临时表

若何用一条sql语句查看所有表的注释?