怎么理解PostgreSQL12 COPY和bulkloading有什么特性
发表于:2025-01-21 作者:千家信息网编辑
千家信息网最后更新 2025年01月21日,本篇内容主要讲解"怎么理解PostgreSQL12 COPY和bulkloading有什么特性",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"怎么理解Pos
千家信息网最后更新 2025年01月21日怎么理解PostgreSQL12 COPY和bulkloading有什么特性
本篇内容主要讲解"怎么理解PostgreSQL12 COPY和bulkloading有什么特性",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"怎么理解PostgreSQL12 COPY和bulkloading有什么特性"吧!
业务是否依赖COPY命令加载数据?PostgreSQL12提供了一个新特性,大大加快了加载速度。
COPY:Loading and unloading data as fast as possible
细看PostgreSQL12的COPY语法,发现有两处变动:
1)\h 会有手册文档链接
2)COPY支持WHERE条件
下面是完整语法:
db12=# \h COPYCommand: COPYDescription: copy data between a file and a tableSyntax:COPY table_name [ ( column_name [, ...] ) ] FROM { 'filename' | PROGRAM 'command' | STDIN } [ [ WITH ] ( option [, ...] ) ] [ WHERE condition ]COPY { table_name [ ( column_name [, ...] ) ] | ( query ) } TO { 'filename' | PROGRAM 'command' | STDOUT } [ [ WITH ] ( option [, ...] ) ]where option can be one of: FORMAT format_name FREEZE [ boolean ] DELIMITER 'delimiter_character' NULL 'null_string' HEADER [ boolean ] QUOTE 'quote_character' ESCAPE 'escape_character' FORCE_QUOTE { ( column_name [, ...] ) | * } FORCE_NOT_NULL ( column_name [, ...] ) FORCE_NULL ( column_name [, ...] ) ENCODING 'encoding_name'URL: https://www.postgresql.org/docs/12/sql-copy.html
虽然添加文档链接功能带来便利,但是WHERE过滤功能更加有用。这个功能的目的是什么?当前,COPY只能导入整个文件。但是某些场景下会有问题:很多场景下,人们只想加载数据的一个子集,并且在导出前必须编写大量代码进行过滤。
COPY...WHERE: 导入时过滤
PostgreSQL通过该条件可以轻松地进行过滤。下面讲述一个简单的例子:
db12=# CREATE TABLE t_demo AS SELECT * FROM generate_series(1, 1000) AS id;SELECT 1000
首先先插入1000行数据,然后导出到一个文件:
db12=# COPY t_demo TO '/tmp/file.txt';COPY 1000
最后,再重新导入数据:
db12=# CREATE TABLE t_import (x int);CREATE TABLEdb12=# COPY t_import FROM '/tmp/file.txt' WHERE x < 5;COPY 4db12=# SELECT * FROM t_import; x--- 1 2 3 4(4 rows)
如上说是,过滤数据非常简单直接。需要注意,导出列是"id",导入列是"x"。文件文件不知道导入表的表结构---需要确保过滤导入表的列名。
其他特性
COPY可以将数据发送到UNIX pipe,还可以从pipe中读取数据。如下所示:
db12=# COPY t_demo TO PROGRAM 'gzip -c > /tmp/file.txt.gz';COPY 1000db12=# COPY t_import FROM PROGRAM 'gunzip -c /tmp/file.txt.gz' WHERE x BETWEEN 100 AND 103;COPY 4db12=# SELECT * FROM t_import WHERE x >= 100; x ----- 100 101 102 103(4 rows)
某些场景下,不止想将数据导出。上面场景,我们想导出数据时将数据压缩;导入时将数据解压并过滤。如上所示,这种方法非常简单。
到此,相信大家对"怎么理解PostgreSQL12 COPY和bulkloading有什么特性"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
数据
特性
场景
文件
功能
内容
如上
文档
方法
条件
语法
链接
学习
实用
更深
业务
人们
代码
例子
兴趣
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
新建数据库的排序规则怎么选
服务器主板坏了什么表现
小宇服务器管理
冠位指令只剩下b站服务器了吗
爱无尚app系统软件开发
管理网络安全工作的部门
宝德服务器是哪个厂家的
政府有专门管理网络安全
自己买服务器
湛泸软件开发
如何加入网络安全会议
设备数据库如何建立
南京尚运网络技术有限公司
触宝电话连接不上服务器能修好吗
转嵌入式软件开发要学什么
网络技术部客服工作
阿里巴巴招软件开发
改卷网络技术
用户密码正确连不上服务器
网络安全7.19
数据库结构化方法
淮北库存软件开发平台
网络安全服务器租用域名
数字化城管网络安全
开发板数据库连接
营造网络安全良好氛围
服务器登陆之后怎么用
郑州c语言软件开发费用
惠州销售软件开发费用是多少
网络技术总监 招聘