我使用psql的\dt列出数据库中的所有表,我需要保存结果。
将psql命令的结果导出到文件的语法是什么?
我使用psql的\dt列出数据库中的所有表,我需要保存结果。
将psql命令的结果导出到文件的语法是什么?
当前回答
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
其他回答
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文件。
与往常一样,详细信息请参阅文档
COPY tablename TO '/tmp/output.csv' DELIMITER ',' CSV HEADER;
该命令用于将整个表存储为CSV格式
这种方法适用于从最简单到最复杂的任何psql命令,而不需要对原始命令进行任何更改或调整。
注意:适用于Linux服务器。
将命令的内容保存到一个文件中
模型
read -r -d '' FILE_CONTENT << 'HEREDOC'
[COMMAND_CONTENT]
HEREDOC
echo -n "$FILE_CONTENT" > sqlcmd
例子
read -r -d '' FILE_CONTENT << 'HEREDOC'
DO $f$
declare
curid INT := 0;
vdata BYTEA;
badid VARCHAR;
loc VARCHAR;
begin
FOR badid IN SELECT some_field FROM public.some_base LOOP
begin
select 'ctid - '||ctid||'pagenumber - '||(ctid::text::point) [0]::bigint
into loc
from public.some_base where some_field = badid;
SELECT file||' '
INTO vdata
FROM public.some_base where some_field = badid;
exception
when others then
raise notice 'Block/PageNumber - % ',loc;
raise notice 'Corrupted id - % ', badid;
--return;
end;
end loop;
end;
$f$;
HEREDOC
echo -n "$FILE_CONTENT" > sqlcmd
执行命令
模型
sudo -u postgres psql [some_db] -c “$(cat sqlcmd)” >>sqlop 2>&1
例子
sudo -u postgres psql some_db -c “$(cat sqlcmd)” >>sqlop 2>&1
查看/跟踪您的命令输出
猫 SQLOP
完成了!谢谢!= D
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
\copy是一个postgres命令,可以为任何用户工作。不知道它是否适用于\dt,但一般语法是从以下链接复制的Postgres SQL复制语法
\copy (select * from tempTable limit 100) to 'filenameinquotes' with header delimiter as ','
上述操作将选择查询的输出保存在csv文件提供的文件名中
编辑:
对于我的psql服务器,以下命令工作,这是一个旧版本v8.5
copy (select * from table1) to 'full_path_filename' csv header;