【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库)

这篇具有很好参考价值的文章主要介绍了【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

环境: windows
数据库: postgresql

1.准备脚本

【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库),postgresql数据库,数据库,postgresql,oracle,spring boot,后端,java,spring cloud

  • backUpDb.bat 脚本为备份脚本,双击运行,右键可以选择编辑;
  • restoreDb.bat 脚本为恢复脚本,双击运行,右键选择编辑;
1.1 脚本介绍

【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库),postgresql数据库,数据库,postgresql,oracle,spring boot,后端,java,spring cloud
如上图所示编辑脚本文件,选择你的备份路径和相应的程序执行路径,以及要备份的数据库名称,登录账户(此时不需要密码),编辑好以后进行保存,然后就可以开始进行备份;

  • 恢复脚本同理
  • 两个脚本所需要的exe应用程序如下:
    【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库),postgresql数据库,数据库,postgresql,oracle,spring boot,后端,java,spring cloud

2.开始备份

  • 双击备份脚本
    提示输入密码,此时输入你当前登录用户的密码回车即可(脚本里面不显示输入密码明文和进度,无需担心,输入完成后enter即可)
    【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库),postgresql数据库,数据库,postgresql,oracle,spring boot,后端,java,spring cloud
  • 显示下面画面即为备份成功
    【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库),postgresql数据库,数据库,postgresql,oracle,spring boot,后端,java,spring cloud
  • 去所选路径查看是否含有备份的dump文件(出现.dump文件即为备份成功
    【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库),postgresql数据库,数据库,postgresql,oracle,spring boot,后端,java,spring cloud

3.进行恢复

  • 1.查看备份前的数据库
    【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库),postgresql数据库,数据库,postgresql,oracle,spring boot,后端,java,spring cloud

  • 2.然后删除相应数据库

  • 3.新建同名数据库(新建数据库只写备份前的数据库名称,其他选项一概不填)
    【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库),postgresql数据库,数据库,postgresql,oracle,spring boot,后端,java,spring cloud

  • 4.新建数据库成功(此时可以看到数据库无table信息)
    【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库),postgresql数据库,数据库,postgresql,oracle,spring boot,后端,java,spring cloud

  • 5.开始运行恢复脚本
    输入密码
    【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库),postgresql数据库,数据库,postgresql,oracle,spring boot,后端,java,spring cloud
    密码错误情况如下,此时只需要重新再次运行脚本输入正确密码即可
    【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库),postgresql数据库,数据库,postgresql,oracle,spring boot,后端,java,spring cloud
    恢复成功页面
    【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库),postgresql数据库,数据库,postgresql,oracle,spring boot,后端,java,spring cloud

  • 6.查看恢复后的数据库
    【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库),postgresql数据库,数据库,postgresql,oracle,spring boot,后端,java,spring cloud


3.单张表的备份与恢复

3.1 单张表的备份

其他参数不变,加上-t 和表名即可 注意是小t(大写T代表除去这张表,其他表都备份)
【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库),postgresql数据库,数据库,postgresql,oracle,spring boot,后端,java,spring cloud

3.2 单张表的恢复

【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库),postgresql数据库,数据库,postgresql,oracle,spring boot,后端,java,spring cloud

注意:区分大小写且备份名字和表名最好一致不然容易混淆

多张表的使用:-t[表名1] -t [表名2]

4.常用命令和参数

4.1 备份常用参数
-h host,指定数据库主机名,或者IP
-p port,指定端口号
-U user,指定连接使用的用户名
-W,按提示输入密码
-a,–data-only,只导出数据,不导出表结构
-c,–clean,是否生成清理该数据库对象的语句,比如drop table
-C,–create,是否输出一条创建数据库语句
-f file,–file=file,输出到指定文件中
-n schema,–schema=schema,只转存匹配schema的模式内容
-N schema,–exclude-schema=schema,不转存匹配schema的模式内容
-O,–no-owner,不设置导出对象的所有权
-s,–schema-only,只导致对象定义模式,不导出数据
-t table,–table=table,只转存匹配到的表,视图,序列,可以使用多个-t匹配多个表
-T table,–exclude-table=table,不转存匹配到的表。
-inserts,使用insert命令形式导出数据,这种方式比默认的copy方式慢很多,但是可用于将数据导入到非PostgreSQL数据库。
dbname,指定连接的数据库名称,实际上也是要备份的数据库名称。
4.2 备份常用命令
  • 备份某个database,备份结果以自定义压缩格式输出:
    pg_dump -h localhost -p 5432 -U someuser -F c -b -v -f mydb.backup mydb  
  • 备份某个database,备份结果以SQL文本格式输出,输出结果要包含CREATE DATABASE 语句:
    pg_dump -h localhost -p 5432 -U someuser -C -F p -b -v -f mydb.backup mydb
  • 备份某个database中所有名称以"pay"开头的表,备份结果以自定义压缩格式输出:
    pg_dump -h localhost -p 5432 -U someuser -F c -b -v -t *.pay* -f pay.backup mydb
  • 备份某个database中hr和payroll这两个schema中的所有数据,备份结果以自定义压缩格式输出:
    pg_dump -h localhost -p 5432 -U someuser -F c -b -v -n hr -n payroll -f hr.backup mydb
  • 备份某个database中除public schema中的数据以外的所有数据,备份结果以自定义压缩格式输出:
    pg_dump -h localhost -p 5432 -U someuser -F c -b -v -N public -f all_sch_except_pub.backup mydb
  • 将数据备份为SQL文本文件,且生成INSERT语句,该文件可以用于低版本的PostgreSQL或其它支持SQL的非PostgreSQL数据库
    pg_dump -h localhost -p 5432 -U someuser -F p --column-inserts -f select_tables.backup mydb
  • 目录备份格式:备份时会先创建一个新目录,然后逐一将一个gzip格式的压缩文件和一个列出所有包含结构的文件填充到该目录。
    pg_dump -h localhost -p 5432 -U someuser -F d -f /root/test/ mydb
  • 支持使用备份选项 --jobs(-j),会启动多个线程并行执行当前备份操作
    pg_dump -h localhost -p 5432 -U someuser -j 4 -F d -f /root/test/ mydb
  • 使用pg_dumpall进行全库备份
4.3 还原常用命令
-d, --dbname=名字 连接数据库名字
-f, --file=文件名 输出文件名
-F, --format=c|d|t backup file format (should be automatic)
-l, --list 打印归档文件的 TOC 概述
-v, --verbose 详细模式
--help 显示此帮助信息, 然后退出
--version 输出版本信息, 然后退出恢复控制选项:
-a, --data-only 只恢复数据, 不包括模式
-c, --clean 在重新创建数据库对象之前需要清除(删除)数据库对象
-C, --create 创建目标数据库
-e, --exit-on-error 发生错误退出, 默认为继续
-I, --index=名称 恢复指定名称的索引
-j, --jobs=NUM 可以执行多个任务并行进行恢复工作
-L, --use-list=文件名 从这个文件中使用指定的内容表排序输出
-n, --schema=NAME 在这个模式中只恢复对象
-O, --no-owner 忽略恢复对象所属者
-P, --function=名字(参数) 恢复指定名字的函数
-s, --schema-only 只恢复模式, 不包括数据
-S, --superuser=NAME 使用指定的超级用户来禁用触发器
-t, --table=NAME 恢复指定命字的表
-T, --trigger=NAME 恢复指定命字的触发器
-x, --no-privileges 跳过处理权限的恢复 (grant/revoke)
-1, --single-transaction 作为单个事务恢复
--disable-triggers 在只恢复数据的过程中禁用触发器
--no-data-for-failed-tables 没有恢复无法创建表的数据
--no-security-labels do not restore security labels
--no-tablespaces 不恢复表空间的分配信息
--use-set-session-authorization 使用 SESSION AUTHORIZATION 命令代替ALTER OWNER命令来设置对象所有权

联接选项:
-h, --host=主机名 数据库服务器的主机名或套接字目录
-p, --port=端口号 数据库服务器的端口号
-U, --username=名字 以指定的数据库用户联接
-w, --no-password 永远不提示输入口令
-W, --password 强制口令提示 (自动)
--role=ROLENAME 在恢复前执行SET ROLE操作

参考参数和命令链接:https://www.cnblogs.com/oumi/p/17505700.html文章来源地址https://www.toymoban.com/news/detail-819319.html

到了这里,关于【PostgreSql】本地备份为dump文件与恢复数据库(单表和整个数据库)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • PostgreSQL数据库定时备份脚本

          大多数数据库管理系统都提供了自带的备份工具,可以使用这些工具来进行备份操作。     例如: MySQL:使用 mysqldump 命令进行备份。 PostgreSQL:使用 pg_dump 命令进行备份。       以下是一个用于定时备份 PostgreSQL 数据库的示例脚本。这个脚本将使用 pg_dump 工具来创建

    2024年02月11日
    浏览(14)
  • postgresql数据库定时备份到远程数据库

    1.老规矩,服务器目录结构: conf目录无内容 profile: 其中: 最后一行 export PGPASSWORD=‘root’ 是需要备份的数据库的密码,因为直接用 pg_dump 命令备份需要输入密码交互,而我们需要达到自动备份,所以借助这种方式不需要输入密码 docker-compose.yml: 启动容器: 然后再data目录下面

    2024年02月09日
    浏览(16)
  • 数据库运维——备份恢复

    数据库备份,数据库为school,素材如下 1.创建student和score表 CREATE  TABLE  student ( id  INT(10)  NOT NULL  UNIQUE  PRIMARY KEY  , name  VARCHAR(20)  NOT NULL , sex  VARCHAR(4)  , birth  YEAR, department  VARCHAR(20) , address  VARCHAR(50)  ); 创建score表。SQL代码如下: CREATE  TABLE  score ( id  INT(10)  NOT NU

    2024年02月16日
    浏览(21)
  • 如何备份与恢复MySQL数据库数据

    目录 一、MySQL备份 备份方式 完全备份 差异备份 增量备份 二、常见的备份方法 物理冷备 专用备份工具 mysqldump 或 mysqlhotcopy 启用二进制日志进行增量备份 第三方工具备份 三、MySQL完全备份 四、数据库完全备份分类 物理冷备份与恢复 mysqldump备份与恢复 五、物理冷备份与恢复

    2024年02月16日
    浏览(23)
  • mysql数据库备份和恢复

    数据备份可以分为三种, 热备份。 数据库处于运行状态,此时依赖数据库的日志文件进行备份 温备份。 进行数据备份时数据库服务正常进行,但是数据智能度不能写。 冷备份。数据库处于关闭状态,能够够好的保证数据库的完整性。 逻辑备份。使用软件从数据库中提取数

    2024年02月12日
    浏览(26)
  • MySQL数据库备份与恢复

    在项目的开发过程中数据库的备份是非常重要的,为了防止数据库受到破坏,造成不可估量的损失,所以一定要进行数据库的备份,并且需要掌握数据库恢复方法,在发生数据库损坏的时候,能快速进行数据库恢复。 本文主要介绍MySQL数据表备份与恢复主要的三种方法,包括

    2024年02月12日
    浏览(24)
  • 9-MySQL数据库 数据的备份与恢复

    1.date文件的备份 2.mysqldump 备份 说明: mysqldump是MySQL数据库中的一个实用程序,它主要用于转储(备份)数据库。mysqldump通过生成一个SQL脚本文件,包含从头开始重新创建数据库所必需的(如 CREATE TABLE和INSERT等),来实现数据库的备份和转储。这样,你可以在任何时候通过运

    2024年02月08日
    浏览(25)
  • 数据库实验7---数据库的备份与恢复

    使用mysqldump命令备份数据库studentsdb的所有表,存于D:下,文件名为all_tables.sql。 在MySQL服务器上创建数据库student1,使用mysql命令将备份文件all_tables.sql恢复到数据库student1中。 使用mysqldump命令备份数据库studentsdb的所有表,存于D:下,文件名为s_c.sql。 在MySQL服务器上创建数据

    2024年02月09日
    浏览(24)
  • MySQL数据库的备份与恢复

    备份的主要目的是灾难恢复。 在生产环境中,数据的安全性至关重要。 任何数据的丢失都可能产生严重的后果。 造成数据丢失的原因: 程序错误 人为操作错误 运算错误 磁盘故障 灾难(如火灾、地震)和盗窃 1)物理备份 物理备份:对数据库操作系统的物理文件(如数据

    2024年02月04日
    浏览(20)
  • Mysql数据库增量备份与恢复

    使用 mysqldump 进行完全备份,备份的数据中有重复数据,备份时间与恢复时间长。 而增量备份就是备份自上一次备份之后增加或改变的文件或内容。 1、增量备份的特点: 没有重复数据,备份量不大,时间短 恢复麻烦:需要上次完全备份及完全备份之后所有的增量备份才能恢复

    2024年02月07日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包