免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
1234下一页
最近访问板块 发新帖
查看: 13586 | 回复: 37
打印 上一主题 下一主题

为什么mysql的update有时候会变得狂慢 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2004-12-15 12:14 |只看该作者 |倒序浏览
情况是这样的:
有20张表在同一台机上的同一个mysql下,每个表是百万数量级的记录,写一个测试程序对这些表不停的做insert和update操作,insert和update的比例是9:1,过几十秒就会停在一条update语句上,很长时间无法继续(但不是每一条update都这样),正常的update语句大概零点几毫秒,但是那些停下来等很长时间的update往往要花好几分钟。

请问一下对这种情况有没有合理的解释?有什么解决办法?

论坛徽章:
0
2 [报告]
发表于 2004-12-15 12:42 |只看该作者

为什么mysql的update有时候会变得狂慢

是不是锁死了

最好降低单表记录数,还有减少索引

论坛徽章:
0
3 [报告]
发表于 2004-12-15 12:51 |只看该作者

为什么mysql的update有时候会变得狂慢

你是不是用的win32呀!

论坛徽章:
0
4 [报告]
发表于 2004-12-15 13:21 |只看该作者

为什么mysql的update有时候会变得狂慢

应该不是锁表的缘故,因为这是一个测试程序,同一时间就只有这一个程序在访问这些表
降低单表记录数是个办法,因为单表记录数过大引起操作变慢也可以理解,但问题是为什么会变得这么慢,而且也不是每条update语句都这样,正常的update也是非常快的。
另外,为什么减少索引会有用?

原帖由 "odin_free" 发表:
是不是锁死了

最好降低单表记录数,还有减少索引

论坛徽章:
0
5 [报告]
发表于 2004-12-15 13:28 |只看该作者

为什么mysql的update有时候会变得狂慢

应该不是锁表的缘故,因为这是一个测试程序,同一时间就只有这一个程序在访问这些表
降低单表记录数是个办法,因为单表记录数过大引起操作变慢也可以理解,但问题是为什么会变得这么慢,而且也不是每条update语句都这样,正常的update也是非常快的。
另外,为什么减少索引会有用?

原帖由 "odin_free" 发表:
是不是锁死了

最好降低单表记录数,还有减少索引

论坛徽章:
0
6 [报告]
发表于 2004-12-15 15:01 |只看该作者

为什么mysql的update有时候会变得狂慢

贴出有问题的Update语句看一下

论坛徽章:
0
7 [报告]
发表于 2004-12-15 16:55 |只看该作者

为什么mysql的update有时候会变得狂慢

用的是linux,slaceware

[quote]原帖由 "sanda1"]你是不是用的win32呀![/quote 发表:

论坛徽章:
0
8 [报告]
发表于 2004-12-15 17:07 |只看该作者

为什么mysql的update有时候会变得狂慢

就是这个样子
update t_report set Freport_result = 0, Freport_err_detail = 'DELIVRD', Fmodify_time = '20041214100816', Freport_time = '20041214102231', Fstate  = 0 where  Fstation='hbgmcc' and Fmatchseqno=7562012 and Fseqno=1813920 limit 1;



[quote]原帖由 "carken"]贴出有问题的Update语句看一下[/quote 发表:

论坛徽章:
0
9 [报告]
发表于 2004-12-15 17:15 |只看该作者

为什么mysql的update有时候会变得狂慢

原帖由 "guowei_78" 发表:
就是这个样子
update t_report set Freport_result = 0, Freport_err_detail = 'DELIVRD', Fmodify_time = '20041214100816', Freport_time = '20041214102231', Fstate = 0 where Fstation='hbgmcc' and Fmatchseqno=7562012 and Fseqno=1813920 limit 1;

我的语句和你差不多,跟新6个字段,关键字有4个,和你的比只是少了'limit 1'一句,更新一个30多万记录的表用0.02秒,你可否去掉limit 1试试

论坛徽章:
0
10 [报告]
发表于 2004-12-15 17:25 |只看该作者

为什么mysql的update有时候会变得狂慢

原来是没有用limit的,也是那个问题,后来以为更新太多会有影响才加上limit的
我的不出问题的update语句应该跟你的那个速度差不多,就是搞不明白为什么会有时候就变得那么慢

原帖由 "carken" 发表:

我的语句和你差不多,跟新6个字段,关键字有4个,和你的比只是少了'limit 1'一句,更新一个30多万记录的表用0.02秒,你可否去掉limit 1试试
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP