2006-08-31 01:34:22 +02:00
|
|
|
--
|
|
|
|
-- Test cases for COPY (select) TO
|
|
|
|
--
|
|
|
|
create table test1 (id serial, t text);
|
|
|
|
insert into test1 (t) values ('a');
|
|
|
|
insert into test1 (t) values ('b');
|
|
|
|
insert into test1 (t) values ('c');
|
|
|
|
insert into test1 (t) values ('d');
|
|
|
|
insert into test1 (t) values ('e');
|
|
|
|
create table test2 (id serial, t text);
|
|
|
|
insert into test2 (t) values ('A');
|
|
|
|
insert into test2 (t) values ('B');
|
|
|
|
insert into test2 (t) values ('C');
|
|
|
|
insert into test2 (t) values ('D');
|
|
|
|
insert into test2 (t) values ('E');
|
|
|
|
create view v_test1
|
|
|
|
as select 'v_'||t from test1;
|
|
|
|
--
|
|
|
|
-- Test COPY table TO
|
|
|
|
--
|
|
|
|
copy test1 to stdout;
|
|
|
|
1 a
|
|
|
|
2 b
|
|
|
|
3 c
|
|
|
|
4 d
|
|
|
|
5 e
|
|
|
|
--
|
|
|
|
-- This should fail
|
|
|
|
--
|
|
|
|
copy v_test1 to stdout;
|
|
|
|
ERROR: cannot copy from view "v_test1"
|
|
|
|
HINT: Try the COPY (SELECT ...) TO variant.
|
|
|
|
--
|
|
|
|
-- Test COPY (select) TO
|
|
|
|
--
|
|
|
|
copy (select t from test1 where id=1) to stdout;
|
|
|
|
a
|
|
|
|
--
|
|
|
|
-- Test COPY (select for update) TO
|
|
|
|
--
|
|
|
|
copy (select t from test1 where id=3 for update) to stdout;
|
|
|
|
c
|
|
|
|
--
|
|
|
|
-- This should fail
|
|
|
|
--
|
|
|
|
copy (select t into temp test3 from test1 where id=3) to stdout;
|
|
|
|
ERROR: COPY (SELECT INTO) is not supported
|
|
|
|
--
|
|
|
|
-- This should fail
|
|
|
|
--
|
|
|
|
copy (select * from test1) from stdin;
|
|
|
|
ERROR: syntax error at or near "from"
|
|
|
|
LINE 1: copy (select * from test1) from stdin;
|
|
|
|
^
|
|
|
|
--
|
|
|
|
-- This should fail
|
|
|
|
--
|
|
|
|
copy (select * from test1) (t,id) to stdout;
|
|
|
|
ERROR: syntax error at or near "("
|
|
|
|
LINE 1: copy (select * from test1) (t,id) to stdout;
|
|
|
|
^
|
|
|
|
--
|
|
|
|
-- Test JOIN
|
|
|
|
--
|
|
|
|
copy (select * from test1 join test2 using (id)) to stdout;
|
|
|
|
1 a A
|
|
|
|
2 b B
|
|
|
|
3 c C
|
|
|
|
4 d D
|
|
|
|
5 e E
|
|
|
|
--
|
|
|
|
-- Test UNION SELECT
|
|
|
|
--
|
2008-08-07 03:11:52 +02:00
|
|
|
copy (select t from test1 where id = 1 UNION select * from v_test1 ORDER BY 1) to stdout;
|
2006-08-31 01:34:22 +02:00
|
|
|
a
|
|
|
|
v_a
|
|
|
|
v_b
|
|
|
|
v_c
|
|
|
|
v_d
|
|
|
|
v_e
|
|
|
|
--
|
|
|
|
-- Test subselect
|
|
|
|
--
|
2008-08-07 03:11:52 +02:00
|
|
|
copy (select * from (select t from test1 where id = 1 UNION select * from v_test1 ORDER BY 1) t1) to stdout;
|
2006-08-31 01:34:22 +02:00
|
|
|
a
|
|
|
|
v_a
|
|
|
|
v_b
|
|
|
|
v_c
|
|
|
|
v_d
|
|
|
|
v_e
|
|
|
|
--
|
|
|
|
-- Test headers, CSV and quotes
|
|
|
|
--
|
|
|
|
copy (select t from test1 where id = 1) to stdout csv header force quote t;
|
|
|
|
t
|
|
|
|
"a"
|
|
|
|
--
|
|
|
|
-- Test psql builtins, plain table
|
|
|
|
--
|
|
|
|
\copy test1 to stdout
|
|
|
|
1 a
|
|
|
|
2 b
|
|
|
|
3 c
|
|
|
|
4 d
|
|
|
|
5 e
|
|
|
|
--
|
|
|
|
-- This should fail
|
|
|
|
--
|
|
|
|
\copy v_test1 to stdout
|
|
|
|
ERROR: cannot copy from view "v_test1"
|
|
|
|
HINT: Try the COPY (SELECT ...) TO variant.
|
2010-11-23 21:27:50 +01:00
|
|
|
--
|
2006-08-31 01:34:22 +02:00
|
|
|
-- Test \copy (select ...)
|
|
|
|
--
|
|
|
|
\copy (select "id",'id','id""'||t,(id + 1)*id,t,"test1"."t" from test1 where id=3) to stdout
|
|
|
|
3 id id""c 12 c c
|
|
|
|
--
|
|
|
|
-- Drop everything
|
|
|
|
--
|
|
|
|
drop table test2;
|
|
|
|
drop view v_test1;
|
|
|
|
drop table test1;
|
2012-01-25 22:06:00 +01:00
|
|
|
-- psql handling of COPY in multi-command strings
|
|
|
|
copy (select 1) to stdout\; select 1/0; -- row, then error
|
|
|
|
1
|
|
|
|
ERROR: division by zero
|
|
|
|
select 1/0\; copy (select 1) to stdout; -- error only
|
|
|
|
ERROR: division by zero
|
2022-04-04 14:57:17 +02:00
|
|
|
copy (select 1) to stdout\; copy (select 2) to stdout\; select 3\; select 4; -- 1 2 3 4
|
2012-01-25 22:06:00 +01:00
|
|
|
1
|
|
|
|
2
|
|
|
|
?column?
|
|
|
|
----------
|
|
|
|
3
|
|
|
|
(1 row)
|
|
|
|
|
2022-04-04 14:57:17 +02:00
|
|
|
?column?
|
|
|
|
----------
|
|
|
|
4
|
|
|
|
(1 row)
|
|
|
|
|
2012-01-25 22:06:00 +01:00
|
|
|
create table test3 (c int);
|
2022-04-04 14:57:17 +02:00
|
|
|
select 0\; copy test3 from stdin\; copy test3 from stdin\; select 1; -- 0 1
|
|
|
|
?column?
|
|
|
|
----------
|
|
|
|
0
|
|
|
|
(1 row)
|
|
|
|
|
2012-01-25 22:06:00 +01:00
|
|
|
?column?
|
|
|
|
----------
|
|
|
|
1
|
|
|
|
(1 row)
|
|
|
|
|
|
|
|
select * from test3;
|
|
|
|
c
|
|
|
|
---
|
|
|
|
1
|
|
|
|
2
|
|
|
|
(2 rows)
|
|
|
|
|
|
|
|
drop table test3;
|