我用

pg_dump db_production > postgres_db.dump

然后使用scp将其复制到localhost。

现在当我导入我的本地db时,它给出了一个错误

pg_restore: [archiver] input file appears to be a text format dump. Please use psql.

使用命令行

pg_restore -d db_development postgres_db.dump

当前回答

psql -U <username> -d <database-name> -h <host-name> -f <backup.sql> . p

其他回答

对我来说,就像这样。

C:\Program Files\PostgreSQL\12\bin> psql -U postgres -p 5432  -d dummy -f C:\Users\Downloads\d2cm_test.sql

提供了一个简单的回答,这对我有用,对你也适用于大多数情况

psql -U username -d database_name < dump_file.sql . d

如果上面给出与角色相关的错误,则将username替换为postgres。

psql -U postgres -d database_name < dump_file.sql . d

当我尝试用DBeaver备份db时,我得到了相同的错误。如果有人在Windows上使用DBeaver界面而不是命令行,请确保在备份和恢复设置时选择的格式为tar。

来自pg_dump文档:

例子

将一个名为mydb的数据库转储到一个sql脚本文件:

$ pg_dump mydb > db.sql

要将这样的脚本重载到(新创建的)名为newdb的数据库中:

$ psql -d newdb -f db.sql

将数据库转储到自定义格式的归档文件中:

$ pg_dump -Fc mydb > db.dump

将数据库转储到目录格式的归档文件中:

$ pg_dump -Fd mydb -f dumpdir

将一个归档文件重新加载到一个名为newdb的(新创建的)数据库中:

$ pg_restore -d newdb db.dump

来自pg_restore文档:

例子

假设我们已经将一个名为mydb的数据库转储到一个自定义格式的转储文件中:

$ pg_dump -Fc mydb > db.dump

删除数据库并从转储中重新创建数据库:

$ dropdb mydb
$ pg_restore -C -d postgres db.dump

为了使用pg_dump创建与pg_restore兼容的备份,在创建转储时必须使用——format=custom / -Fc。

从文档中可以看出:

输出适合输入到pg_restore的自定义格式的存档。

所以你的pg_dump命令可能是这样的:

pg_dump --file /tmp/db.dump --format=custom --host localhost --dbname my-source-database --username my-username --password

你的pg_restore命令:

pg_restore --verbose --clean --no-acl --no-owner --host localhost --dbname my-destination-database /tmp/db.dump