我试图通过命令行导出一个带有标题的PostgreSQL表到CSV文件,但是我把它导出到CSV文件,但没有标题。
我的代码如下:
COPY products_273 to '/tmp/products_199.csv' delimiters',';
我试图通过命令行导出一个带有标题的PostgreSQL表到CSV文件,但是我把它导出到CSV文件,但没有标题。
我的代码如下:
COPY products_273 to '/tmp/products_199.csv' delimiters',';
当前回答
我之所以发布这个答案,是因为这里给出的其他答案都不适合我。我不能从Postgres内部使用COPY,因为我没有正确的权限。所以我选择“Export grid rows”并将输出保存为UTF-8。
由于不同的原因,@Brian给出的psql版本也不适合我。它不起作用的原因显然是Windows命令提示符(我使用的是Windows)自己干扰了编码。我一直得到这个错误:
错误:字节序列为0x81的字符在编码“WIN1252”时没有对应的编码“UTF8”
我最终使用的解决方案是编写一个简短的JDBC脚本(Java),读取CSV文件并直接向Postgres表发出插入语句。这是可行的,但是如果没有改变编码,命令提示符也可以工作。
其他回答
这是
psql dbname -F , --no-align -c "SELECT * FROM TABLE"
COPY命令不是受限制的。限制的是将输出从TO指向除STDOUT之外的任何地方。但是,通过\o命令指定输出文件没有限制。
\o '/tmp/products_199.csv';
COPY products_273 TO STDOUT WITH (FORMAT CSV, HEADER);
这个解决方案为我工作使用\copy。
psql -h <host> -U <user> -d <dbname> -c "\copy <table_name> FROM '<path to csvfile/file.csv>' with (format csv,header true, delimiter ',');"
试试这个: “从\tmp\products_199.csv' DELIMITER ',' CSV头'复制products_273”
当我没有权限从Postgres写文件时,我发现我可以从命令行运行查询。
psql -U user -d db_name -c "Copy (Select * From foo_table LIMIT 10) To STDOUT With CSV HEADER DELIMITER ',';" > foo_data.csv