這篇文章主要講解了“怎么使用PostgreSQL中的COPY命令”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“怎么使用PostgreSQL中的COPY命令”吧!
創(chuàng)新互聯(lián)建站長(zhǎng)期為1000+客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為復(fù)興企業(yè)提供專業(yè)的成都做網(wǎng)站、成都網(wǎng)站建設(shè),復(fù)興網(wǎng)站改版等技術(shù)服務(wù)。擁有十年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。
Copy命令在PG 12有所增強(qiáng),在COPY FROM時(shí)可添加WHERE條件過濾.
PG 11
Copy命令
testdb=# \help copy Command: COPY Description: copy data between a file and a table Syntax: COPY table_name [ ( column_name [, ...] ) ] FROM { 'filename' | PROGRAM 'command' | STDIN } [ [ WITH ] ( option [, ...] ) ] COPY { table_name [ ( column_name [, ...] ) ] | ( query ) } TO { 'filename' | PROGRAM 'command' | STDOUT } [ [ WITH ] ( option [, ...] ) ] where option can be one of: FORMAT format_name OIDS [ boolean ] 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'
簡(jiǎn)單使用
testdb=# drop table if exists t_copy; DROP TABLE testdb=# CREATE TABLE t_copy(id int,c1 varchar(20)); CREATE TABLE testdb=# insert into t_copy SELECT x,'c1-'||x FROM generate_series(1, 1000) AS x; INSERT 0 1000 testdb=# testdb=# COPY t_copy TO '/tmp/data/t_copy.txt' with DELIMITER '|'; COPY 1000 testdb=# drop table if exists t_import; DROP TABLE testdb=# CREATE TABLE t_import(id int,c1 varchar(20)); CREATE TABLE testdb=# COPY t_import FROM '/tmp/data/t_copy.txt' with DELIMITER '|'; COPY 1000 testdb=# select * from t_import limit 10; id | c1 ----+------- 1 | c1-1 2 | c1-2 3 | c1-3 4 | c1-4 5 | c1-5 6 | c1-6 7 | c1-7 8 | c1-8 9 | c1-9 10 | c1-10 (10 rows)
不支持WHERE條件過濾
testdb=# COPY t_import FROM '/tmp/data/t_copy.txt' with DELIMITER '|' where id < 5; ERROR: syntax error at or near "where" LINE 1: ...t FROM '/tmp/data/t_copy.txt' with DELIMITER '|' where id <...
PG 12
COPY命令語法
[local]:5432 pg12@testdb=# \help copy Command: COPY Description: copy data between a file and a table Syntax: 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條件過濾
[local]:5432 pg12@testdb=# drop table if exists t_copy; DROP TABLE Time: 50.327 ms [local]:5432 pg12@testdb=# CREATE TABLE t_copy(id int,c1 varchar(20)); CREATE TABLE Time: 5.038 ms [local]:5432 pg12@testdb=# insert into t_copy SELECT x,'c1-'||x FROM generate_series(1, 1000) AS x; INSERT 0 1000 Time: 16.422 ms [local]:5432 pg12@testdb=# [local]:5432 pg12@testdb=# COPY t_copy TO '/tmp/data/t_copy.txt' with DELIMITER '|'; COPY 1000 Time: 4.795 ms [local]:5432 pg12@testdb=# drop table if exists t_import; DROP TABLE Time: 4.798 ms [local]:5432 pg12@testdb=# CREATE TABLE t_import(id int,c1 varchar(20)); CREATE TABLE Time: 2.462 ms [local]:5432 pg12@testdb=# COPY t_import FROM '/tmp/data/t_copy.txt' with DELIMITER '|' WHERE id < 5; COPY 4 Time: 4.842 ms [local]:5432 pg12@testdb=# select * from t_import; id | c1 ----+------ 1 | c1-1 2 | c1-2 3 | c1-3 4 | c1-4 (4 rows) Time: 6.103 ms
感謝各位的閱讀,以上就是“怎么使用PostgreSQL中的COPY命令”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)怎么使用PostgreSQL中的COPY命令這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!