我试图通过命令行导出一个带有标题的PostgreSQL表到CSV文件,但是我把它导出到CSV文件,但没有标题。

我的代码如下:

COPY products_273 to '/tmp/products_199.csv' delimiters',';

当前回答

最简单的方法(使用psql)似乎是使用——csv标志:

psql --csv -c "SELECT * FROM products_273" > '/tmp/products_199.csv'

其他回答

最简单的方法(使用psql)似乎是使用——csv标志:

psql --csv -c "SELECT * FROM products_273" > '/tmp/products_199.csv'

当我没有权限从Postgres写文件时,我发现我可以从命令行运行查询。

psql -U user -d db_name -c "Copy (Select * From foo_table LIMIT 10) To STDOUT With CSV HEADER DELIMITER ',';" > foo_data.csv

试试这个: “从\tmp\products_199.csv' DELIMITER ',' CSV头'复制products_273”

COPY命令不是受限制的。限制的是将输出从TO指向除STDOUT之外的任何地方。但是,通过\o命令指定输出文件没有限制。

\o '/tmp/products_199.csv';
COPY products_273 TO STDOUT WITH (FORMAT CSV, HEADER);
COPY products_273 TO '/tmp/products_199.csv' WITH (FORMAT CSV, HEADER);

如手册所述。