PostgreSQL 数据库备份与还原

为了安全与数据共享等,创建好的数据库有时候需要备份操作和还原操作。数据库的备份与还原主要是三个命令:pg_dump、pg_dumpall 和 pg_restore

其中pg_dump用于备份单个数据库 ,它支持多种备份格式 (SQL、自定义等),可以备份特定表或模式。pg_dumpall用于备份整个数据库集群 (包括所有数据库和全局对象),输出为纯文本SQL脚本pg_restore:用于从备份文件中恢复数据库,支持从 SQL 文件或自定义格式文件恢复,可以选择恢复特定表或模式。

每一个命名都有很多参数和用法,对于pg_dump命令官网提供了详细的介绍:https://www.postgresql.org/docs/17/app-pgdump.html

下面是三个命令最简单的用法:

sql 复制代码
# pg_dump命令
pg_dump [参数] 数据库名称 > 输出文件
# 将mydatabase数据库备份为一个SQL文件
pg_dump -U postgres mydatabase > mydatabase.sql
# 上面代码中,-U指定连接的用户名,常用的参数还有:使用 -h 和 -p 指定主机和端口

# pg_dumpall
pg_dumpall [参数] > 输出文件
# 备份整个数据库集群
pg_dumpall -U 用户名 -h 主机 -p 端口 > 所有数据库备份.sql

# pg_restore
pg_restore [参数] -d 数据库名称 输入文件
# 从 SQL 文件恢复
psql -U 用户名 -d mydatabase < mydatabase_backup.sql
# 从自定义格式文件恢复
pg_restore -U 用户名 -d mydatabase -F c mydatabase_backup.custom
# -F format:指定备份文件的格式(p:纯文本SQL,c:自定义格式,d:目录格式)。

此外,在之前的学习中,还接触了使用pgAdmin进行备份与重载,当时仅仅进行了简单的重载。

但是官网也提供了详细的数据库备份与重载教程,包括大量的参数设置介绍等:https://www.pgadmin.org/docs/pgadmin4/development/backup_and_restore.html

相关推荐
风向决定发型丶1 小时前
redis集群搭建
数据库·redis·缓存
wei_shuo3 小时前
KES 扩展与插件开发实战:自定义函数、触发器与第三方插件集成
数据库·kes
风中芦苇啊3 小时前
从直接生成到受控配置:新一代图表Agent的SQL安全生成范式
数据库·sql·安全
吴声子夜歌4 小时前
SQL进阶——窗口函数
数据库·sql
周杰伦的稻香4 小时前
MySQL8.0+中引入的SET_USER_ID权限迭代SUPER权限指定 DEFINER
数据库·mysql
动恰客流统计4 小时前
客流统计如何结合AI分析?从传统计数到智能决策的技术升级路径
数据库·人工智能·边缘计算
宠友信息5 小时前
多端数据互通场景下Spring Boot仿小红书源码结构设计
数据库·spring boot·redis·缓存·架构
风曦Kisaki5 小时前
#Linux数据库管理Day06:主从同步与MaxScale读写分离
linux·运维·数据库
影寂ldy5 小时前
C# try-catch 异常处理全套笔记
服务器·数据库·c#
长不胖的路人甲5 小时前
Redis 缓存的数据持久化方案讲解
数据库·redis·缓存