pgsql-使用dump命令制作数据库结构、数据快速备份bat脚本

一、背景

通过pgsql的dump命令可以快速的做数据库表结构、表数据的备份,随着业务不断的增加单库单实例已经不能满足业务需要。技术人员是比较懒惰的,每次敲相同命令或是无脑的复制黏贴操作感觉都是对精神的一种摧残,解决摧残的方法就是把命令写成批处理文件,每次双击下搞定!!!

二、环境

  • windows 10
  • pgsql 14

三、快速备份脚本

  1. 新建个bak-pg_dump.bat文件,将一下内容保存到bat文件中

    goto start
    ::功能:基于pgsql的dump命令,实现数据库表结构和数据库表数据的导出
    ::使用:1.修改pgslq安装目录dump变量;2.修改目标库密码PGPASSWORD变量;3.修改目标库实例database变量;4.按需增减schema变量和对应的pg_dump指令;
    ::修改日期:2024-07-16
    :start
    @echo off
    echo dir=%cd%
    set dump=D:\Program Files\PostgreSQL\14\bin
    set PGPASSWORD=********
    ::database
    set database=mydatabase
    ::管理库
    set schema_admin_top=myschema
    ::结构转存
    "%dump%\pg_dump" --host=127.0.0.1 --port=5432 --username=postgres --schema=%schema_admin_top% --schema-only --no-owner --verbose --encoding=UTF8 %database% > %cd%\struct-%schema_admin_top%.sql
    ::数据转存
    "%dump%\pg_dump" --host=127.0.0.1 --port=5432 --username=postgres --schema=%schema_admin_top% --data-only --column-inserts --no-owner --verbose --encoding=UTF8 %database% > %cd%\data-%schema_admin_top%.sql
    pause

  2. 命令的使用方法

  • 新建个文件夹,按需要修改文件夹名称;
  • 将bak-pg_dump.bat文件复制到文件件内;
  • 双击bak-pg_dump.bat执行批处理;
  • 等待命令执行完毕,目录下将生成struct-.sql和data-.sql文件
  • struct开头的为库表结构备份脚本;
  • data开头的为库表数据备份脚本;

四、遇到的问题和解决方案

  1. 提示"LOCK TABLE test.xxxx IN ACCESS SHARE MODE"错误

    常见错误和解决:
    pg_dump: 最后的内置 OID 是 16383
    pg_dump: 读扩展
    pg_dump: 识别扩展成员
    pg_dump: 读取模式
    pg_dump: 读取用户定义表
    pg_dump: 错误: 查询失败: 閿欒: 瀵硅〃 xxxx 鏉冮檺涓嶅
    pg_dump: 错误: 查询是: LOCK TABLE test.xxxx IN ACCESS SHARE MODE

这个问题是在postgresql中使用pg_dump备份执行备份表结构时遇到的问题,产生这个问题的原因是pg_dump需要使用超级用户。

更改 --username参数,使用超级用户或postgres用户解决问题。

总结

通过bat将每次需要重复执行的cd命令、输入pgsql密码、修改执行脚本等重复操作都避免了,减少工作量的同时可以将此类备份操作交由运维人员定期完成。

相关推荐
计算机毕设VX:Fegn08958 小时前
计算机毕业设计|基于springboot + vue医院设备管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
Mr__Miss8 小时前
保持redis和数据库一致性(双写一致性)
数据库·redis·spring
Knight_AL9 小时前
Spring 事务传播行为 + 事务失效原因 + 传播行为为什么不用其他模式
数据库·sql·spring
倔强的石头_9 小时前
时序数据时代的“存储与分析困局”解析及金仓解决方案
数据库
计算机毕设VX:Fegn08959 小时前
计算机毕业设计|基于springboot + vue小型房屋租赁系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
倔强的石头_10 小时前
场景化落地指南——金仓时序数据库在关键行业的应用实践
数据库
SelectDB11 小时前
驾驭 CPU 与编译器:Apache Doris 实现极致性能的底层逻辑
运维·数据库·apache
zbguolei11 小时前
MySQL根据身份证号码计算出生日期和年龄
数据库·mysql
马克学长12 小时前
SSM校园图书借阅服务系统jd2z8(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·图书管理系统·ssm 框架·ssm 校园图书借阅系统
软件派12 小时前
高斯数据库使用心得——从性能优化到行业实践的深度解析
数据库·oracle