一条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的主要内容,如果未能解决你的问题,请参考以下文章