Экспортируйте таблицу PostgreSQL в CSV с заголовками, только если количество строк в таблице больше 0 - PullRequest
0 голосов
/ 02 июля 2018

Я экспортирую таблицу в CSV с заголовком, используя команду COPY в postgreSQL. Даже если результат таблицы равен 0, он создает файл CSV только с заголовком. Мне нужен файл CSV с заголовком, только если количество строк больше 0.

1 Ответ

0 голосов
/ 02 июля 2018

Вы можете просто plpgsql это:

db=# do $$
begin
if (select count(*) from t) > 0 then
copy t to '/tmp/t' with (format csv, header);
end if;
end;
$$
;
DO
db=# \! cat /tmp/t
c
2
db=# truncate table t;
TRUNCATE TABLE
db=# \! rm /tmp/t
db=# do $$
begin
if (select count(*) from t) > 0 then
copy t to '/tmp/t' with (format csv, header);
end if;
end;
$$
;
DO
db=# \! cat /tmp/t
cat: /tmp/t: No such file or directory
...