当前位置: 首页 > news >正文

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
  1. 命令的使用方法
  • 新建个文件夹,按需要修改文件夹名称;
  • 将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密码、修改执行脚本等重复操作都避免了,减少工作量的同时可以将此类备份操作交由运维人员定期完成。

http://www.lryc.cn/news/403673.html

相关文章:

  • 【3D编程技巧】如何用四元数旋转矢量在相机空间进行光照计算
  • ICMP 和 IGMP 的区别
  • 【Vue3】工程创建及目录说明
  • 算法学习2——排序算法(2)
  • 嵌入式人工智能(9-基于树莓派4B的PWM-LED呼吸灯)
  • python-NLP:1中文分词
  • iOS 开发包管理之CocoaPods
  • Windows搭建RTMP视频流服务器
  • VS2019安装MFC组件
  • Python学习—open函数,json与pickle知识点,Os模块详解
  • 基于SSM的高考志愿选择辅助系统
  • 引领小模型潮流!OpenAI发布功能强大且成本低的GPT-4o mini
  • 【考研数学】线代满分经验分享+备考复盘
  • Java项目:基于SSM框架实现的海鲜自助餐厅系统【ssm+B/S架构+源码+数据库+毕业论文】
  • 前端面试题日常练-day97 【Less】
  • 压缩视频大小的方法 怎么减少视频内存大小 几个简单方法
  • JVM:GraalVM
  • 海外营销推广:快速创建维基百科(wiki)词条-大舍传媒
  • 【HarmonyOS】HarmonyOS NEXT学习日记:五、交互与状态管理
  • 处理uniapp刷新后,点击返回按钮跳转到登录页的问题
  • 工厂方法模式java
  • java模拟多ip请求【搬代码】
  • 微软史诗级的蓝屏
  • HALCON数据结构
  • 数据库系统概论:事务与并发一致性问题
  • Python编程基础:元组类型、字典类型、集合类型
  • day2 单机并发缓存
  • ECMP等价多路由机制,大模型训练负载均衡流量极化冲突原因,万卡(大规模)集群语言模型(LLM)训练流量拥塞特点
  • Linux 注意事项
  • 力扣SQL50 指定日期的产品价格 双重子查询 coalesce