我用

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

当前回答

如果你用这种方式备份,我想这会更容易导入数据库。

pg_dump -h(远端数据库地址)-a——column-inserts -U postgres(数据库名)>(文件名).sql

对于进口,

psql -f(文件名).sql ——host(远程数据库地址) ——端口5432 ——用户名postgres ——password(你的密码) ——dbname(你要导入的数据库)

其他回答

我也一直在为这个问题挣扎。这是dump和restore命令的组合,对我来说很有效:

pg_dump -Ft -C -h database_host -U username database > DATA.dump

恢复

pg_restore -x --no-owner -d database DATA.dump

如果您想在您的DB中保持相同的访问权限(acl),请删除-x标志。为此,在数据库中必须具有相同的角色和用户。

https://www.postgresql.org/docs/15/app-pgdump.html

https://www.postgresql.org/docs/15/app-pgrestore.html

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

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

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

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

如果您恢复。sql文件。 在pgAdmin中创建一个新数据库。 进入终端,浏览.sql文件所在的文件夹/目录。然后在终端中写入以下命令。

让: 超自然用户后

Examaple:

sudo -u postgres psql newDb < restoreDb.sql

上面的答案对我没用,下面这个有用:

PSQL db_development < postgres_db.dump

这是解,

pg_restore -U username -p 5432 -h 10.10.10.1 -d database_name < dump_file . pg_restore -U username -p 5432