免费注册 查看新帖 |

Chinaunix

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

perl将大量数据复制到数据库 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-12-05 15:56 |只看该作者 |倒序浏览
请问有没有办法用perl将大量数据直接复制到数据库而不是一条一条的插入?
类似bulkcopy的功能

论坛徽章:
0
2 [报告]
发表于 2012-12-05 16:21 |只看该作者
应该是数据库系统提供的功能

论坛徽章:
0
3 [报告]
发表于 2012-12-05 16:23 |只看该作者
同意楼上,这个要问数据库,不能问perl吧

论坛徽章:
0
4 [报告]
发表于 2012-12-05 16:45 |只看该作者
我用c#可以实现,只是现在在我的perl程序中也需要,但不知怎么用

论坛徽章:
0
5 [报告]
发表于 2012-12-05 17:19 |只看该作者
回复 4# xi0ws


    这个意思是不知道perl怎么和数据库交互? 模块 DBI

论坛徽章:
0
6 [报告]
发表于 2012-12-05 17:25 |只看该作者
bind_param_array

可以用这个。。。不过要注意,如果数据量太大的话,可能导致内存不足的。

论坛徽章:
0
7 [报告]
发表于 2012-12-05 19:11 |只看该作者
本帖最后由 xi0ws 于 2012-12-05 19:12 编辑

用bind_param_array貌似性能提升不明显,插入100,000条数据用时157.624秒
直接用$sth->execute(), 自己控制commit用时156.930秒

论坛徽章:
42
19周年集字徽章-周
日期:2019-10-14 14:35:31平安夜徽章
日期:2015-12-26 00:06:30数据库技术版块每日发帖之星
日期:2015-12-01 06:20:002015亚冠之首尔
日期:2015-11-04 22:25:43IT运维版块每日发帖之星
日期:2015-08-17 06:20:00寅虎
日期:2014-06-04 16:25:27狮子座
日期:2014-05-12 11:00:00辰龙
日期:2013-12-20 17:07:19射手座
日期:2013-10-24 21:01:23CU十二周年纪念徽章
日期:2013-10-24 15:41:34IT运维版块每日发帖之星
日期:2016-01-27 06:20:0015-16赛季CBA联赛之新疆
日期:2016-06-07 14:10:01
8 [报告]
发表于 2012-12-06 08:46 |只看该作者
仅对oracle而言,perl的数组批量插入比proc的慢很多,还不如单条,批量提交的
这个应该是DBD实现的问题
追求性能,还是考虑其他方法吧。

论坛徽章:
0
9 [报告]
发表于 2012-12-08 12:51 |只看该作者
回复 1# xi0ws


    maatkit是perl写的,里面有个db sync的工具。
perl用来写了大量的mysql DBA工具,maatkit, MHA, mysqlreport, ZRM, mycheckpoint, MySQLTuner等。

论坛徽章:
0
10 [报告]
发表于 2012-12-10 11:35 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP