魏晓东 发表于 2024-9-12 11:13:47

【PostgreSql本地备份为dump文件与规复】单张表、整个数据库的备份dump与恢

环境:windows数据库:postgresql 1.预备脚本

https://i-blog.csdnimg.cn/blog_migrate/81032ec91f64e571f79408de2ffa4adf.png


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

https://i-blog.csdnimg.cn/blog_migrate/a1e4bf9bd9e721f46ea804f35b560a8e.png
如上图所示编辑脚本文件,选择你的备份路径和相应的程序实验路径,以及要备份的数据库名称,登录账户(此时不需要密码),编辑好以后举行生存,然后就可以开始举行备份;


[*]规复脚本同理
[*]两个脚本所需要的exe应用程序如下:
https://i-blog.csdnimg.cn/blog_migrate/7274f519b53a2172c12046f730ee75d2.png
2.开始备份



[*]双击备份脚本
提示输入密码,此时输入你当前登任命户的密码回车即可(脚本内里不显示输入密码明文和进度,无需担心,输入完成后enter即可)
https://i-blog.csdnimg.cn/blog_migrate/a8ffe2b92fa1be8627fa197c768e3ec3.png
[*]显示下面画面即为备份成功
https://i-blog.csdnimg.cn/blog_migrate/33c9eadef19fc5d32cb186816146666a.png
[*]去所选路径查察是否含有备份的dump文件(出现.dump文件即为备份成功)
https://i-blog.csdnimg.cn/blog_migrate/bdc0b287564ec4a81181bd2951c8c0e9.png
3.举行规复



[*] 1.查察备份前的数据库
https://i-blog.csdnimg.cn/blog_migrate/b02d8a894aaa8ac398bad8bb594454f2.png
[*] 2.然后删除相应数据库
[*] 3.新建同名数据库(新建数据库只写备份前的数据库名称,其他选项一概不填)
https://i-blog.csdnimg.cn/blog_migrate/a2fd9d1a02b0ae03ff7eba3d168f07e7.png
[*] 4.新建数据库成功(此时可以看到数据库无table信息)
https://i-blog.csdnimg.cn/blog_migrate/b699d3400dc39b7005f9e064ac040406.png
[*] 5.开始运行规复脚本
输入密码
https://i-blog.csdnimg.cn/blog_migrate/b7b4cdb3ad9c33b7cdcb27e5e094dbf5.png
密码错误环境如下,此时只需要重新再次运行脚本输入精确密码即可
https://i-blog.csdnimg.cn/blog_migrate/6ebb40924f38b41593216f7dbf28abf8.png
规复成功页面
https://i-blog.csdnimg.cn/blog_migrate/a79501d857e30c2bf144d85fcc756124.png
[*] 6.查察规复后的数据库
https://i-blog.csdnimg.cn/blog_migrate/317aeb47a6e12c94cb68e959435f9d4c.png
3.单张表的备份与规复

3.1 单张表的备份

其他参数稳定,加上-t 和表名即可 注意是小t(大写T代表撤除这张表,其他表都备份)
https://i-blog.csdnimg.cn/blog_migrate/d1dc1dd9bb743f595da9720b1ab78046.png
3.2 单张表的规复

https://i-blog.csdnimg.cn/blog_migrate/cf7d0f9e34f713d981b4e70e446753d5.png
注意:区分大小写且备份名字和表名最好一致否则容易混淆
   多张表的使用:-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

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 【PostgreSql本地备份为dump文件与规复】单张表、整个数据库的备份dump与恢