【PostgreSql本地备份为dump文件与恢复】单张表、整个数据库的备份dump与恢复
创始人
2025-01-15 12:09:12
0

目录

      • 1.准备脚本
        • 1.1 脚本介绍
      • 2.开始备份
      • 3.进行恢复
      • 3.单张表的备份与恢复
        • 3.1 单张表的备份
        • 3.2 单张表的恢复
      • 4.常用命令和参数
        • 4.1 备份常用参数
        • 4.2 备份常用命令
        • 4.3 还原常用命令

环境:windows
数据库:postgresql

1.准备脚本

在这里插入图片描述

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

在这里插入图片描述
如上图所示编辑脚本文件,选择你的备份路径和相应的程序执行路径,以及要备份的数据库名称,登录账户(此时不需要密码),编辑好以后进行保存,然后就可以开始进行备份;

  • 恢复脚本同理
  • 两个脚本所需要的exe应用程序如下:
    在这里插入图片描述

2.开始备份

  • 双击备份脚本
    提示输入密码,此时输入你当前登录用户的密码回车即可(脚本里面不显示输入密码明文和进度,无需担心,输入完成后enter即可)
    在这里插入图片描述
  • 显示下面画面即为备份成功
    在这里插入图片描述
  • 去所选路径查看是否含有备份的dump文件(出现.dump文件即为备份成功
    在这里插入图片描述

3.进行恢复

  • 1.查看备份前的数据库
    在这里插入图片描述

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

  • 3.新建同名数据库(新建数据库只写备份前的数据库名称,其他选项一概不填)
    在这里插入图片描述

  • 4.新建数据库成功(此时可以看到数据库无table信息)
    请添加图片描述

  • 5.开始运行恢复脚本
    输入密码
    请添加图片描述
    密码错误情况如下,此时只需要重新再次运行脚本输入正确密码即可
    请添加图片描述
    恢复成功页面
    请添加图片描述

  • 6.查看恢复后的数据库
    请添加图片描述


3.单张表的备份与恢复

3.1 单张表的备份

其他参数不变,加上-t 和表名即可 注意是小t(大写T代表除去这张表,其他表都备份)
在这里插入图片描述

3.2 单张表的恢复

在这里插入图片描述

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

多张表的使用:-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

相关内容

热门资讯

2024版新版!微扑克ai辅助... 2024版新版!微扑克ai辅助(软件透明挂)WPK德州版其实是真的有挂(2025已更新)(哔哩哔哩)...
十分钟系统微扑克透明挂(软件透... 您好,德扑之星这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款游戏...
一分钟ai代打wpk后台管理系... 一分钟ai代打wpk后台管理系统(辅助挂)教你教程(2022已更新)(哔哩哔哩);AI辅助机器人普及...
什么是VPN服务器 VPN是指“虚拟专用网络”,属于远程访问技术,能够加密用户的互联网流量&...
C#与西门子PLC1500的M...  1、客户端选择客户端可以是一个程序或一个设备,这里我以C#WINFORM程序来实现客...
使用Nginx正向代理通过互联... 一、资源准备1.nginx-1.20.22.proxy_connect_rewrite_1018.p...
SOME/IP协议详解[2 S... 目录2.1 SOME/IP 传输层协议2.2 SOME/IP-SD服务发现(Service Disc...
八次轻量版wpk有猫腻(软件透... 八次轻量版wpk有猫腻(软件透明挂)wepoke存在外挂(2021已更新)(哔哩哔哩)是一款可以让一...
十分钟安卓版!wepoke有插... 十分钟安卓版!wepoke有插件(软件透明挂)Wepoke新版原来是有挂猫腻(2021已更新)(哔哩...
四个漏洞aapoker有规律(... 亲,aapoker这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别...