免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3841 | 回复: 1

pg_dump的增强版本 [复制链接]

论坛徽章:
0
发表于 2009-05-24 21:54 |显示全部楼层
pg_dump 是postgresql自带的备份导出工具, 其中有个选项 --table="模式名.表名"可以导出某个表.

因为在实际应用中,想倒出表的部分数据,希望有类似mysqldump中的where功能,于是

我重新修改了pg_dump, 让table选项扩展, 加上where表达式, 可以选择条件输出

具体用法 --table="模式名.表名 where ....",若要多个表,可多加几个--table选项.

如 pg_dump --table="public.test where t_id>100 order by t_id" 数据库名.
where请用小写

分享请参考:
http://blog.chinaunix.net/u/24767/showart_1941445.html

注:
版本8.3.3, 用mingw编译的, 压缩库为mgwz.dll .
版本8.3.6, 用vc2005编译的, 压缩库为zlib1.dll .
源文件:修改处 请搜索 table_where字眼

(注意,谨慎用以全表恢复, 因为加where导出的数据,不是表的全部,如果DROP了表,再恢复,将导致原表数据不全)

论坛徽章:
0
发表于 2009-05-31 18:12 |显示全部楼层

回复 #1 trainee 的帖子

我这是么做的,先select into到一个临时表中,然后copy to这个临时表,导入时用copy from,速度不比pg_dump慢
btw,有无copy时使用delimiter的替代方案?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP