PostgreSQL备份工具pg_dump和pg_dumpall
PostgreSQL使用 pg_dump 和 pg_dumpall 进行数据库的逻辑备份,pg_dumpall 是对整个数据库集群进行备份,pg_dump 可以选择一个数据库或者部分表进行备份。
pg_dump 将表结构及数据以SQL语句的形式导出到文件中,恢复数据时,将导出的文件作为输入,执行其中的SQL语句,即可恢复数据。
pg_dump 能够对正在使用的PostgreSQL数据库进行备份,并且不影响正常业务的读写。
一、前期准备
1、数据库版本:PostgreSQL 12.0
2、创建文件夹,并赋予权限
mkdir /home/haolb/pgbak chown –R postgres /home/haolb/pgbak
3、Liunx系统正常切换到postgres用户
[root@localhost haolb]# su postgres bash-4.2$
二、pg_dump 常用示例
1 导出单表数据 pg_dump -h 127.0.0.1 -U postgres -p 5432 -W oyzData_CivilAirDefence_NeiMengGu_Xilinguolemeng_postgresql -t oyz_menu --inserts > oyz_menu.sql 2 导出多个表数据 pg_dump -h 127.0.0.1 -U postgres -p 5432 -W oyzData_CivilAirDefence_NeiMengGu_Xilinguolemeng_postgresql -t oyz_menu -t sys_user --inserts > oyz_menu_user.sql 3 导出整个数据库 pg_dump -h 127.0.0.1 -U postgres -p 5432 -E UTF8 -W oyzData_CivilAirDefence_NeiMengGu_Xilinguolemeng_postgresql --inserts > bak.sql 4 只导出表结构,不导出数据 pg_dump -h 127.0.0.1 -U postgres -p 5432 -E UTF8 -W oyzData_CivilAirDefence_NeiMengGu_Xilinguolemeng_postgresql -s > tableDMLbak.sql 5 只导出数据,不导出表结构 pg_dump -h 127.0.0.1 -U postgres -p 5432 -E UTF8 -W oyzData_CivilAirDefence_NeiMengGu_Xilinguolemeng_postgresql -a > tableDMLbak.sql
三、pg_dump常用参数
-h host,指定数据库主机名,或者IP
-p port,指定端口号
-U user,指定连接使用的用户名
-W,按提示输入密码
dbname,指定连接的数据库名称,实际上也是要备份的数据库名称。
-a,–data-only,只导出数据,不导出表结构
-c,–clean,是否生成清理该数据库对象的语句,比如drop table
-C,–create,是否输出一条创建数据库语句
-E, --encoding=ENCODING,导出数据编码格式(UTF8、GBK)
-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数据库。
--column-inserts,导出的数据,有显式列名
四、pg_dumpall
相对于pg_dump只能备份单个库,pg_dumpall可以备份整个postgresql实例中所有的数据,包括角色和表空间定义。
示例如下:
pg_dumpall -h 127.0.0.1 -U admin -p 5432 –W --inserts > bak.sql
五、报错解决方法
bash-4.2$ pg_dump -h 127.0.0.1 -U postgres -p 5432 -W oyzData_CivilAirDefence_NeiMengGu_Xilinguolemeng_postgresql --inserts > bak.sql |
在备份正个库时报以上错误,说明字符编码有问题,导出时加上 –E参数。
pg_dump -E UTF8
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析