我使用psql的\dt列出数据库中的所有表,我需要保存结果。

将psql命令的结果导出到文件的语法是什么?


当前回答

从psql的帮助(\?):

\o [FILE]将所有查询结果发送到文件或|管道

命令序列如下所示:

[wist@scifres ~]$ psql db
Welcome to psql 8.3.6, the PostgreSQL interactive terminal

db=>\o out.txt
db=>\dt

然后任何db操作输出都将被写入out.txt。 输入'\o'将输出恢复到控制台。

db=>\o

其他回答

psql \o命令已经由jhwist描述。

另一种方法是使用COPY TO命令直接写入服务器上的文件。这样做的好处是,它被转储为您选择的易于解析的格式——而不是psql的表格格式。使用COPY FROM导入到另一个表/数据库也很容易。

NB !这需要超级用户或pg_write_server_files权限,并将写入服务器上的文件。

示例:COPY (SELECT foo, bar FROM baz) TO '/tmp/query.csv' (format csv, delimiter ';')

创建一个以';'作为字段分隔符的CSV文件。

与往常一样,详细信息请参阅文档

我假设存在一些内部的psql命令,但你也可以从util-linux-ng包中运行脚本命令:

描述 脚本使打印在终端上的所有内容的typescript。

从psql的帮助(\?):

\o [FILE]将所有查询结果发送到文件或|管道

命令序列如下所示:

[wist@scifres ~]$ psql db
Welcome to psql 8.3.6, the PostgreSQL interactive terminal

db=>\o out.txt
db=>\dt

然后任何db操作输出都将被写入out.txt。 输入'\o'将输出恢复到控制台。

db=>\o

使用下面的查询将结果存储在CSV文件中

\copy (your query) to 'file path' csv header;

例子

\copy (select name,date_order from purchase_order) to '/home/ankit/Desktop/result.csv' cvs header;

希望这对你有所帮助。

docker方法

通过PSQL命令

 docker exec -i %containerid% psql -U %user% -c '\dt' > tables.txt

或从SQL文件查询

docker exec -i %containerid% psql -U %user% < file.sql > data.txt