用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > mysql教程

mysql Copying to tmp table on disk 影响性能

时间:2015-01-23  来源:西部数据  作者:西部数据

在使用mysql是突然发现提醒mysql Copying to tmp table on disk 错误了,下面我们来看看此问题的解决办法.

经过查资料发现mysql可以通过变量tmp_table_size和max_heap_table_size来控制内存表大小上限,如果超过上限会将数据写到磁盘上,从而会有物理磁盘的读写操作,导致影响性能.

我们可以通过调整这两个变量的值来提升性能,当然前提条件是mysql所在服务器有足够的内存.

首先可以通过下面语句查看当前的变量值:

SHOW VARIABLES LIKE ‘max_heap_table_size%’;

然后通过SET GLOBAL max_heap_table_size=522715200; 设置变量值为512M,你可以根据自己的情况设置合适的值,tmp_table_size变量的设置方法一样.

SHOW VARIABLES LIKE ‘tmp_table_size’;

SET GLOBAL max_heap_table_size=512*1024*1024;

其次发现开发人员编写的语句,根本无法使用到缓存,这个sql优化是个长期的过程,代码如下:

  1. # Time: 140901 16:26:23 
  2. # User@Host: wealth[wealth] @ [172.20.1.70] 
  3. # Query_time: 2266.887211 Lock_time: 0.000196 Rows_sent: 17 Rows_examined: 71501657 
  4. SET timestamp=1409559983; 
  5. SELECT a.Pid,count(a.id) as count,p.ProductId,p.ProductName,p.ProductType,p.Profit,p.StartTime,p.EndTime,p.StartMoney,p.AddTime,i.IssuerName FROM `Issuer`as i,`Countas a left join Product as p on a.Pid=p.ProductId WHERE a.Stime > ‘time() – 3600*24*30′ and p.IssuerId=i.IssuerId AND p.IsDel=0 group by a.Pid order by count(a.id) desc limit 0,17; 
  6. //开源代码phpfensi.com
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
栏目更新
栏目热门