在pgAdmin中将整个数据库(其结构和数据)复制到新数据库的正确方法是什么?


当前回答

以下是仅使用pgadmin4 GUI(通过备份和恢复)在数据库上创建复制的整个过程

Postgres附带Pgadmin4。如果你使用macOS,你可以按CMD+SPACE并键入pgadmin4来运行它。这将在chrome中打开一个浏览器选项卡。


复制步骤

1.创建备份

通过右键单击数据库->“备份”来执行此操作

2.为文件命名。

如测试12345。单击备份。这将创建一个二进制文件转储,它不是.sql格式

3.查看下载位置

屏幕右下角应该有一个弹出窗口。单击“更多详细信息”页面,查看备份下载到的位置

4.查找下载文件的位置

在本例中,它是/users/vincenttang

5.从pgadmin还原备份

假设您正确执行了步骤1到4,您将得到一个还原二进制文件。有时,您的同事可能希望在其本地计算机上使用您的还原文件。让此人转到pgadmin并恢复

通过右键单击数据库->“还原”来执行此操作

6.选择文件查找器

确保手动选择文件位置,不要将文件拖放到pgadmin中的上传器字段。因为您将遇到错误权限。相反,找到您刚刚创建的文件:

7.查找所述文件

您可能需要将右下角的筛选器更改为“所有文件”。此后,从步骤4查找文件。现在点击右下角的“选择”按钮确认

8.还原所述文件

您将再次看到此页面,其中选择了文件的位置。继续并恢复它

9.成功

如果一切正常,右下角将弹出一个指示器,显示成功恢复。您可以导航到表,查看每个表上的数据是否已正确还原。

10.如果不成功:

如果步骤9失败,请尝试删除数据库中的旧公共架构。转到“查询工具”

执行此代码块:

DROP SCHEMA public CASCADE; CREATE SCHEMA public;

现在再次尝试步骤5至9,应该会成功

编辑-一些附加说明。如果您在上传过程中遇到错误,在还原过程中出现类似“archiver header 1.14 unsupported version”的内容,请更新PGADMIN4

其他回答

在pgAdmin中打开主窗口,然后打开另一个查询工具窗口在pgAdmin的主窗口中,

断开要用作模板的“模板化”数据库。

转到查询工具窗口

运行2个查询,如下所示

SELECT pg_terminate_backend(pg_stat_activity.pid) 
    FROM pg_stat_activity 
    WHERE pg_stat_activity.datname = 'TemplateDB' AND pid <> pg_backend_pid(); 

(上面的SQL语句将终止与TemplateDB的所有活动会话,然后您现在可以选择它作为模板来创建新的TargetDB数据库,这样可以避免出现已在使用的错误。)

CREATE DATABASE 'TargetDB'
  WITH TEMPLATE='TemplateDB'
       CONNECTION LIMIT=-1;

在pgAdmin中,您可以从原始数据库进行备份,然后只需创建一个新数据库并从刚刚创建的备份中恢复:

右键单击源数据库,备份。。。并转储到文件。右键单击,新建对象,新建数据库。。。并命名目的地。右键单击新数据库,还原。。。然后选择文件。

在pgAdmin中将整个数据库(其结构和数据)复制到新数据库的正确方法是什么?

答覆:

CREATE DATABASE newdb WITH TEMPLATE originaldb;

经过尝试和测试。

以下是仅使用pgadmin4 GUI(通过备份和恢复)在数据库上创建复制的整个过程

Postgres附带Pgadmin4。如果你使用macOS,你可以按CMD+SPACE并键入pgadmin4来运行它。这将在chrome中打开一个浏览器选项卡。


复制步骤

1.创建备份

通过右键单击数据库->“备份”来执行此操作

2.为文件命名。

如测试12345。单击备份。这将创建一个二进制文件转储,它不是.sql格式

3.查看下载位置

屏幕右下角应该有一个弹出窗口。单击“更多详细信息”页面,查看备份下载到的位置

4.查找下载文件的位置

在本例中,它是/users/vincenttang

5.从pgadmin还原备份

假设您正确执行了步骤1到4,您将得到一个还原二进制文件。有时,您的同事可能希望在其本地计算机上使用您的还原文件。让此人转到pgadmin并恢复

通过右键单击数据库->“还原”来执行此操作

6.选择文件查找器

确保手动选择文件位置,不要将文件拖放到pgadmin中的上传器字段。因为您将遇到错误权限。相反,找到您刚刚创建的文件:

7.查找所述文件

您可能需要将右下角的筛选器更改为“所有文件”。此后,从步骤4查找文件。现在点击右下角的“选择”按钮确认

8.还原所述文件

您将再次看到此页面,其中选择了文件的位置。继续并恢复它

9.成功

如果一切正常,右下角将弹出一个指示器,显示成功恢复。您可以导航到表,查看每个表上的数据是否已正确还原。

10.如果不成功:

如果步骤9失败,请尝试删除数据库中的旧公共架构。转到“查询工具”

执行此代码块:

DROP SCHEMA public CASCADE; CREATE SCHEMA public;

现在再次尝试步骤5至9,应该会成功

编辑-一些附加说明。如果您在上传过程中遇到错误,在还原过程中出现类似“archiver header 1.14 unsupported version”的内容,请更新PGADMIN4

复制“欠载”数据库

我把这个方法和上面的例子拼凑在一起。我正在一台“负载不足”的服务器上工作,当我尝试使用@zbyszek的方法时出错。我也在寻求“仅限命令行”的解决方案。

createdb:数据库创建失败:错误:其他用户正在访问源数据库“exampledb”。

以下是对我有效的方法(命令前加nohup,以将输出移动到文件中并防止服务器断开连接):

nohup pg_dump示例b>example-01.sqlcreatedb-O postgres示例bclone_01我的用户是“postgres”nohup psql示例bclone_01<示例-01.sql