如何将PostgreSQL转储文件恢复到Postgres数据库?

我有一个具有.sql扩展名的转储文件(实际上它是一个纯文本的sql文件)。我想恢复到我创建的数据库。我使用 pgAdmin III,当我使用它的“恢复向导”它不突出显示“恢复”按钮。而是期待一个.backup文件扩展名。

我尝试使用shell来恢复转储的命令,但仍然没有起作用。

我是这个新手。如果有人能帮助我,我有义务。

编辑

我在PostGres的Shell sql窗格中使用以下命令,而坐在newTestDB上。

newTestDB-# \i E:\db-rbl-restore-20120511_Dump-20120514.sql

它仍然提供相同的错误(“权限被拒绝”)。

升级权限后,它只显示Postgresql认表:

List of tablespaces
Name       |  Owner   | Location
-----------+----------+----------
pg_default | postgres |
pg_global  | postgres |

(2 rows)

我不知道如何从sql文件导入/恢复数据库

你没有提到你的备份是如何做的,所以通用的答案是:通常使用psql工具。

根据指定要转储的pg_dump,sql文件可以有不同的sql命令集。
例如,如果您指示pg_dump使用–clean和-schema-only转储数据库,则无法期望能够从该转储恢复数据库,因为没有用于copYing的sql命令(或者INSERTing if – 使用插入表)表中的实际数据。像这样的转储将仅包含DDL sql命令,并且将能够重新创建模式而不是实际的数据。

使用psql恢复典型的sql转储:

psql (connection options here) database  < yourbackup.sql

或者从psql会话中,

psql (connection options here) database
database=# \i /path/to/yourbackup.sql

在使用pg_dump -Fc(“自定义格式”)进行备份的情况下,这不是纯文本而是压缩文件,您需要使用pg_restore工具。

如果您正在使用unix,请尝试:

man psql
man pg_dump
man pg_restore

否则,看看the html docs.祝你好运!

相关文章

项目需要,有个数据需要导入,拿到手一开始以为是mysql,结果...
本文小编为大家详细介绍“怎么查看PostgreSQL数据库中所有表...
错误现象问题原因这是在远程连接时pg_hba.conf文件没有配置正...
因本地资源有限,在公共测试环境搭建了PGsql环境,从数据库本...
wamp 环境 这个提示就是说你的版本低于10了。 先打印ph...
psycopg2.OperationalError: SSL SYSCALL error: EOF detect...