Postgres copy命令导入导出数据的操作方法
前言
最近有需要对数据进行迁移的需求,由于postgres性能的关系,单表3000W的数据量查询起来有一些慢,需要对大表进行切割,拆成若干个子表,涉及到原有数据要迁移到子表的需求。起初的想法是使用存储过程,使用select insert方式进行,但是数据量大的时候耗时有点久,于是需要想别的办法,就发现了postgres本身支持的copy命令。
copy命令
COPY在PostgreSQL表和文件之间交换数据。 COPY TO把一个表的所有内容都拷贝到一个文件,而COPY FROM从一个文件里拷贝数据到一个表里(把数据附加到表中已经存在的内容里)。 COPY TO还能拷贝select查询的结果。
如果声明了一个字段列表,COPY将只在文件和表之间拷贝已声明字段的数据。 如果表中有任何不在字段列表里的字段,那么COPY FROM将为那些字段插入缺省值。
带文件名的COPY指示PostgreSQL服务器直接从文件中读写数据。 如果声明了文件名,那么服务器必须可以访问该文件,而且文件名必须从服务器的角度声明。 如果使用了PROGRAM选项,则服务器会从指定的这个程序进行输入或是写入该程序作为输出。 如果使用了STDIN 或STDOUT选项,那么数据将通过客户端和服务器之间的连接来传输。
常用参数说明:
table_name
现存表的名字(可以有模式修饰)
column_name
可选的待拷贝字段列表。如果没有声明字段列表,那么将使用所有字段
query
一个必须用圆括弧包围的select或VALUES命令,其结果将被拷贝
filename
输入或输出文件的路径名。输入文件名可以是绝对或是相对的路径,但输出文件名必须是绝对路径。 Windows用户可能需要使用E”字符串和双反斜线作为路径名称
PROGRAM
需执行的程序名。在COPY FROM命令中,输入是从程序的标准输出中读取,而在COPY TO中,命令的输出会作为程序的标准输入。
注意,程序一般是在命令行界面下执行,当用户需要传递一些变量给程序时,如果这些变量的来源不是可靠的,用户必须小心过滤处理那些对命令行界面来说是有特殊意义的字符。 基于安全的原因,最好是使用固定的命令字符串,或者至少是应避免直接使用用户输入(应先过滤特殊字符)
STDOUT
声明输入将写入客户端应用
FORMAT
选择被读或者写的数据格式:text、csv(逗号分隔值),或者binary。 默认是text
导出CSV:
命令:
copy to的导出速度非常之快,经测试10W的数据量只需要3秒左右的时间
示例:
也可以导出指定的属性:
也可以使用select 语句:
也可以指定要导出哪些字段:
导入CSV:
命令:
示例:
导入命令基本与导出一样,只是将TO 改为 FROM
如果导出的时候,指定了header属性,那么在导入的时候,也需要指定:
注意事项:
第一点:
copy命令必须在plsql命令行执行,执行用户必须为superuser,否则会提示:
ERROR: must be superuser to COPY to or from a file
HINT: Anyone can COPY to stdout or from stdin. psql's \copy command also works for anyone.
普通用户进行执行,需要在copy前面加入 “\”,即 \copy即可
第二点:
如果导出的字段,有integer[]类型,直接导出,再导入的话,会有问题,解决办法是需要在导出的时候,进行处理:
更多详细信息,可以查看官方文档:
http://www.postgres.cn/docs/9.3/sql-copy.html
栏 目:PostgreSQL
下一篇:PostgreSQL,为什么它成为开发者首选的数据库系统?
本文标题:Postgres copy命令导入导出数据的操作方法
本文地址:https://fushidao.cc/shujuku/803.html
您可能感兴趣的文章
- 02-26请问包含哪些关键词的词条会涉及postgresql数据扩展名?
- 02-26我国在postgresql国产替代方面有哪些进展和挑战?
- 02-26关于PostgreSQL列标志,这些关键信息你了解多少?
- 02-26为何我的PostgreSQL连接速度如此缓慢?常见原因及优化方法解析
- 02-26如何快速上手使用PostgreSQL工具?详细入门教程揭秘!
- 02-26关于PostgreSQL时间类型的最小可能值,您知道多少?
- 02-26如何构建包含PostgreSQL存储过程与事务处理的完整词条示例?
- 02-26如何全面掌握使用postgresql客户端工具的详细教程及技巧?
- 02-26苹果电脑macOS下如何通过命令行安装PostgreSQL而非Postman?
- 02-25如何实现 PostgreSQL 数据库的简单扩容策略?详细解析与疑问解答
阅读排行
- 1请问包含哪些关键词的词条会涉及postgresql数据扩展名?
- 2我国在postgresql国产替代方面有哪些进展和挑战?
- 3关于PostgreSQL列标志,这些关键信息你了解多少?
- 4为何我的PostgreSQL连接速度如此缓慢?常见原因及优化方法解析
- 5如何快速上手使用PostgreSQL工具?详细入门教程揭秘!
- 6关于PostgreSQL时间类型的最小可能值,您知道多少?
- 7如何构建包含PostgreSQL存储过程与事务处理的完整词条示例?
- 8如何全面掌握使用postgresql客户端工具的详细教程及技巧?
- 9苹果电脑macOS下如何通过命令行安装PostgreSQL而非Postman?
- 10如何实现 PostgreSQL 数据库的简单扩容策略?详细解析与疑问解答
推荐教程
- 09-22navicat连接postgresql、人大金仓等数据库报错解决办法
- 02-01PostgreSQL和MySQL到底有什么区别?开发者必看对比指南
- 09-22PostgreSQL设置主键自增的方法详解
- 09-22postgresql查询今天、昨天、本周、本月、上月、今年、去年的时间以及计算时间之差
- 09-22在PostgreSQL中实现跨数据库的关联查询
- 09-22使用python-slim镜像遇到无法使用PostgreSQL的问题及解决方法
- 09-22Postgres copy命令导入导出数据的操作方法
- 02-01PostgreSQL客户端工具大揭秘,哪种最适合你的数据库管理需求?
- 01-31PostgreSQL下载指南,如何获取最新稳定版本?
- 09-22postgresql 日期查询最全整理
