免费注册 查看新帖 |

Chinaunix

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

请教perl从Mysql抽取数据:Mysql client ran out of memory [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-09-07 17:59 |只看该作者 |倒序浏览
我用perl写了个抽取数据的小程序,在oracle,sqlserver数据库上抽数据,从来没遇到过问题。但是在mysql上,只要数据量过大的,就会报错,这次我要抽取的一张表,大约800M,然后就报错了:Mysql client ran out of memory
  1. my $dbh = DBI->connect($dsnname,$user,$pwd) or errlog("connect err: $DBI::errstr");

  2.         $dbh->{LongReadLen} = 8000 * 1024;

  3.         my $sth = $dbh->prepare($sqlstatement) or errlog("prepare err: $dbh->errstr");
  4.         my $rv = $sth->execute() or errlog("execute err: $dbh->errstr");

  5.         while (@data = $sth->fetchrow_array())
复制代码
是不是mysql数据库,fetch的时候,会把查询结果集的所有数据都取到内存里面捏。。怎么这么傻,呵呵,希望各位给点建议,非常感谢  

论坛徽章:
78
双子座
日期:2013-10-15 08:50:09天秤座
日期:2013-10-16 18:02:08白羊座
日期:2013-10-18 13:35:33天蝎座
日期:2013-10-18 13:37:06狮子座
日期:2013-10-18 13:40:31双子座
日期:2013-10-22 13:58:42戌狗
日期:2013-10-22 18:50:04CU十二周年纪念徽章
日期:2013-10-24 15:41:34巨蟹座
日期:2013-10-24 17:14:56处女座
日期:2013-10-24 17:15:30双子座
日期:2013-10-25 13:49:39午马
日期:2013-10-28 15:02:15
2 [报告]
发表于 2010-09-07 18:06 |只看该作者
参数设置问题吧

论坛徽章:
0
3 [报告]
发表于 2010-09-07 18:52 |只看该作者
请问是在哪儿设置呢?是Mysql的设置问题还是perl要限制arraysize类似的东西?

论坛徽章:
1
申猴
日期:2014-04-18 16:29:14
4 [报告]
发表于 2010-09-07 20:06 |只看该作者
试试更改LongTruncOk?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP