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

postgresql|数据库|恢复备份的时候报错:pg_restore: implied data-only restore的处理方案

一,

前情回顾

某次在使用pg_dump命令逻辑备份出来的备份文件对指定的几个表恢复的时候,报错pg_restore: implied data-only restore  

当然,遇到问题首先就是百度了,但好像没有什么明确的解决方案,具体的报错命令和报错信息如下:

[postgres@node1 ~]$ pg_restore -Upostgres -v -x  -d   pgbench -t ds.dr_route_ds -t ds.dr_task_active_ds 2023-08-02T04_00-ds.dump 
pg_restore: connecting to database for restore
pg_restore: implied data-only restore

第二行表示pg_restore 命令已经正确连接到数据库,数据库名称是pgbench,准备开始备份

第三行表示    暗示恢复命令是仅恢复数据,然后就没有然后了!!!!

what  fa?

二,

问题分析和解决方案

仔细观察这个备份命令,发现是-d 数据库名称  -t 模式名称.该模式下的表名 -t 模式名称.该模式下的表名 -t 模式名称.该模式下的表名

OK,将模式名称去掉,发现可以正常的恢复了

postgres@node1 ~]$ pg_restore -Upostgres -v -x -a  -d   pgbench -t dr_route_ds -t dr_task_active_ds 2023-08-02T04_00-ds.dump 
pg_restore: connecting to database for restore
pg_restore: processing data for table "dr.dr_route_ds"
pg_restore: processing data for table "dr.dr_task_active_ds"
pg_restore: processing data for table "ds.dr_route_ds"
pg_restore: processing data for table "ds.dr_task_active_ds"

但出现了一个问题,pgbench这个数据库下有两个scheme,也就是两个模式,两个模式有同样的两张表,我现在只想恢复ds模式下的这两张表的数据,并不想恢复dr模式下的这两张表的数据

因此,最终的恢复命令为加 -n参数,-指定ds模式:

[postgres@node1 ~]$ pg_restore -Upostgres -v -x -a  -d   pgbench -n ds -t dr_route_ds -t dr_task_active_ds 2023-08-02T04_00-ds.dump 
pg_restore: connecting to database for restore
pg_restore: processing data for table "ds.dr_route_ds"
pg_restore: processing data for table "ds.dr_task_active_ds"

####注:

  • 参数-v 是显示恢复的过程,通常此参数是必加的
  • 参数-a 是只覆盖恢复数据不检查对象是否存在,比如,要恢复的表已存在,这个不检查,只把表数据覆盖到表内
  • 参数-x 如果逻辑备份文件内有包含权限的对象,例如用户什么的,使用此参数的时候将不执行相关操作,例如,某个用户的创建在此逻辑备份文件内,但不会执行,也不会检查
  • 参数-d 指定要恢复到哪个数据库内,也就是目标数据库
  • 参数-n 指定目标数据库下的scheme,也就是模式名称
  • 参数-t  指定要恢复的表的表名
  • 最后,逻辑备份文件前面不要加任何参数

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

相关文章:

  • Elasticsearch:使用 Langchain 和 OpenAI 进行问答
  • 安全巡检管理系统—隐患排查治理
  • 第9期ThreadX视频教程:自制个微秒分辨率任务调度实现方案(2023-10-11)
  • C++ 11 lamdba表达式详解
  • Linux运行环境搭建系列-Zookeeper安装
  • vscode利用lauch.json和docker中的delve调试本地crdb
  • 【java|golang】多字段排序以及排序规则
  • 腾讯云 轻量云 上海 VPS 测评
  • 消息称苹果或在明年推出搭载M3芯片的MacBook产品
  • Generalizable NeRF in ICCV‘23
  • Unity2017适配安卓12
  • ios UI 基础开发一
  • echarts一些配置项的使用
  • python yaml库:safe_load()(安全解析函数,解析yaml)(防止yaml文件中包含恶意代码)
  • 小程序:下拉刷新+上拉加载+自定义导航栏
  • 判断两个二叉树是否相等
  • springcloud----检索中间件 ElasticSearch 分布式场景的运用
  • qt创建线程类并实现通信 C++
  • 【elasticsearch】使用自建证书搭建elasticsearch8.0.1集群
  • 一篇文章带你用动态规划解决打家劫舍问题
  • idea中导入eclipse的javaweb项目——tomact服务(保姆级别)
  • 【开源】给ChatGLM写个,Java对接的SDK
  • 基于Pytest+Allure+Excel的接口自动化测试框架
  • 20.2 FMC驱动SDRAM的时序初始化实现及内存测试
  • 联想电脑一键重装系统Win10操作方法
  • Mysql数据库 1.概述
  • Qt编程,文件操作、UDP通信
  • Docker 的数据管理和Dockerfile镜像的创建
  • [python] 利用 Pydoc 快速生成整个 Python 项目的文档
  • Maven 配置指南