openGauss指定schema下全部表结构备份与恢复

本次测试针对openGauss版本为2.0.5

gs_dump指定schema下全部表结构信息备份

gs_dump database_name -U username -p port -F c -s -n schema_name -f schema.sqldatabase_name:数据库名,要备份的数据库名称
username:用户名,数据库用户
port:数据库端口号
schema_name:schema名称
schema.sql:生成的备份文件,也可以写为绝对路径/xxx/xxx/xxx.sql,文件后缀无具体要求,也可以用txt等可读取文件-F c:尝试使用 -F c、-F d 或 -F t 来指定备份文件的归档格式。根据您的需求选择适当的格式,可能是定制格式 (c)、目录格式 (d) 或 TAR 格式 (t)
-s:只备份表结构
-n:需要备份的schema
-f:指定备份文件和路径
其他参数可以参考官方文档

gs_restore恢复指定schema下全部表结构信息

gs_restore schema.sql -U username -p port -d database_name -C -c -s -n schema_name-n schema_name:只导入已列举的模式中的对象。该选项可与-t选项一起用以导入某个指定的表。多次输入-n _schemaname_可以导入多个模式。经测试,当按照上述命令进行备份后,备份文件内含有create schema 语句,若不指定schema,此参数可以省略。
-C:—create
导入到数据库之前先创建数据库。(选择该选项后,-d指定的数据库将被用作发布首个CREATE DATABASE命令。所有数据将被导入到创建的数据库中。)
-c:—clean
在重新创建数据库对象前,清理(删除)已存在于将要还原的数据库中的数据库对象。

测试过程:

参数:
database_name:postgres
username:dbmon
port:26000
schema_name:test
schema.sql:test.sql
  • 准备工作:

1.创建用户

CREATE USER username [WITH PASSWORD 'password'];
创建schemacreate schema dbmon

2.用户赋权

GRANT privilege_name [, ...] ON object_name TO username [, ...];
其中,privilege_name 是要授予的权限名称,如 SELECTINSERTUPDATE 等;object_name 是要授权的对象名称,如表、视图等;username 是要授予权限的用户名。可以使用逗号分隔来指定多个权限、对象和用户

3.登录openGauss

gsql -d datatest -U dbmon -p 26000

4.创建schema

/**
如果需要切换数据库
\c <database_name>
**/
create schema test;

5.准备数据

openGauss=> set search_path to test;
SET
openGauss=>  create table test.a(id int,score int);
CREATE TABLE
openGauss=>  create table test.b(id int,num int);
CREATE TABLE
openGauss=> insert into test.a values(1,20),(2,40),(3,50);
INSERT 0 3
openGauss=> insert into test.b values(1,1),(2,2),(3,3);
INSERT 0 3
;

6.开始备份

[omm@cmbcog25 opengauss30]$ gs_dump postgres -U dbmon -p 26000 -F c -s -n test -f test.sql
Password:
gs_dump[port='26000'][postgres][2023-10-10 14:11:24]: The total objects number is 402.
gs_dump[port='26000'][postgres][2023-10-10 14:11:25]: [100.00%] 402 objects have been dumped.
gs_dump[port='26000'][postgres][2023-10-10 14:11:25]: dump database postgres successfully
gs_dump[port='26000'][postgres][2023-10-10 14:11:25]: total time: 7166  ms

7.删除数据

openGauss=> drop schema ad cascade;
NOTICE:  drop cascades to 2 other objects
DETAIL:  drop cascades to table ad.a
drop cascades to table ad.b
DROP SCHEMA
/**也可以换一台没有数据openGauss进行恢复**/

8.恢复schema和表结构信息

[omm@cmbcog25 opengauss30]$ gs_restore test.sql -U dbmon -p 26000  -d postgres -C -c -s
Password:
start restore operation ...
Finish reading 5 SQL statements!
end restore operation ...
restore operation successful
total time: 2508  ms

9.检查表结构

/**检查schema**/
openGauss=> \dnList of schemasName       |   Owner
-----------------+-----------test              | dbmon
(1 rows)/**检查表**/
openGauss=> SELECT table_name
FROM information_schema.tables
WHERE table_schema = 'test';table_name
------------ab
(2 rows)/**检查表结构**/openGauss=>  select column_name, data_type, character_maximum_length, is_nullable, column_default  from information_schema.columns where table_schema='test' ;column_name | data_type | character_maximum_length | is_nullable | column_default
-------------+-----------+--------------------------+-------------+----------------num         | integer   |                          | YES         |id          | integer   |                          | YES         |score       | integer   |                          | YES         |id          | integer   |                          | YES         |
(4 rows)openGauss=> select column_name, data_type, character_maximum_length, is_nullable, column_default  from information_schema.columns where table_schema='test' and table_name='a';column_name | data_type | character_maximum_length | is_nullable | column_default
-------------+-----------+--------------------------+-------------+----------------score       | integer   |                          | YES         |id          | integer   |                          | YES         |
(2 rows)

表内无数据,备份恢复成功!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/104932.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

跨行或跨列布局

关键点 1、float 实现 2、flex 实现 3、grid 实现效果预览: html: <div class="container"><h2>float 实现</h2>

10.12按键中断

设置按键中断&#xff0c;按键1按下&#xff0c;LED亮&#xff0c;再按一次&#xff0c;灭 按键2按下&#xff0c;蜂鸣器响。再按一次&#xff0c;不响 按键3按下&#xff0c;风扇转&#xff0c;再按一次&#xff0c;风扇停 keyit.h: #ifndef __KEYIT_H__ #define __KEYIT_…

对计算思维的培养

斯坦福大学在 “ 下个十年计算机课程开设情况方案中提出了新的 核心课程体系&#xff0c;包括计算机数学基础、计算机科学中的概率论、数据 结构和算法的理论核心课程&#xff0c;以及包括抽象思维和编程方法、计算机 系统与组成、计算机系统和网络原理在内的系统核心课程。…

Go语言介绍与安装

介绍与安装 本教程介绍了 Go&#xff0c;并讨论了选择 Go 相对于其他编程语言的优势。我们还将学习如何在Windows 中安装 Go。 介绍 Go也称为Golang&#xff0c;是由 Google 开发的一种开源、编译型、静态类型的编程语言。 Go创造背后的关键人物是Rob Pike、 Ken Thompson和…

Blender:渲染一个简单动画

接上 Blender&#xff1a;对模型着色_六月的翅膀的博客-CSDN博客 目标是做一个这种视频 先添加一个曲线&#xff0c;作为相机轨迹 然后添加一个相机 对相机添加物体约束&#xff0c;跟随路径&#xff0c;选择曲线&#xff0c;然后点击动画路径 假如对相机设置跟随路径后&…

STM32_驱动蜂鸣器自定义库

STM32_驱动蜂鸣器自定义库 功能说明&#xff1a; 1、可以实现设置蜂鸣器的音调 2、可以设置蜂鸣器连续鸣响次数 3、设置连续鸣响时间间隔 main.c #include "mymain.h" #include "dev_control.h"int main(void) {HAL_Init();SystemClock_Config();MX_GPIO_…

Linux高性能服务器编程 学习笔记 第十三章 多进程编程

我们将讨论Linux多进程编程的以下内容&#xff1a; 1.复制进程映像的fork系统调用和替换进程映像的exec系列系统调用。 2.僵尸进程以及如何避免僵尸进程。 3.进程间通信&#xff08;Inter Process Communication&#xff0c;IPC&#xff09;最简单的方式&#xff1a;管道。 …

SSM - Springboot - MyBatis-Plus 全栈体系(二十六)

第六章 SpringBoot 快速启动框架&#xff1a;SpringBoot3 实战 一、SpringBoot3 介绍 1. SpringBoot3 简介 SpringBoot 版本&#xff1a;3.0.5 到目前为止已经学习了多种配置 Spring 程序的方式。但是无论使用 XML、注解、Java 配置类还是他们的混合用法&#xff0c;都会觉…

String、StringBuilder、StringBuffer区别

String、StringBuilder、StringBuffer区别 面试官&#xff1a;请你谈谈String、StringBuilder、StringBuffer区别 作为经典Java八股&#xff0c;是面试必考的热门点。 下面让我们一起来看一下他们的区别吧&#xff01; 主要是测试他们的效率和应用场景&#xff0c;具体语法不在…

浅谈机器学习中的概率模型

浅谈机器学习中的概率模型 其实&#xff0c;当牵扯到概率的时候&#xff0c;一切问题都会变的及其复杂&#xff0c;比如我们监督学习任务中&#xff0c;对于一个分类任务&#xff0c;我们经常是在解决这样一个问题&#xff0c;比如对于一个n维的样本 X [ x 1 , x 2 , . . . .…

Git问题汇总

1.取消全局代理 一般报错Failed to connect to github.com port 443 after 21089 ms: Couldn’t connect to server 取消全局代理&#xff1a; git config --global --unset http.proxygit config --global --unset https.proxy####2.git 推送出现 "fatal: The remote e…

Google云平台构建数据ETL任务的最佳实践

在数据处理中&#xff0c;我们经常需要构建ETL的任务&#xff0c;对数据进行加载&#xff0c;转换处理后再写入到数据存储中。Google的云平台提供了多种方案来构建ETL任务&#xff0c;我也研究了一下这些方案&#xff0c;比较方案之间的优缺点&#xff0c;从而找到一个最适合我…

MongoDB的作用和安装方法

MongoDB是一种非关系型数据库&#xff0c;其作用是存储和管理非结构化数据&#xff0c;例如文档、图像和视频等多媒体数据。它有以下几个特点&#xff1a; 数据存储的格式是类似JSON的文档格式&#xff0c;易于理解、存储和查询。可扩展性强&#xff0c;可以在多个服务器上分布…

[资源推荐] 复旦大学张奇老师科研分享

刷B站的时候首页给我推了这个&#xff1a;【直播回放】复旦大学张奇教授亲授&#xff1a;人工智能领域顶会论文的发表指南先前也散漫地读了些许论文&#xff0c;但没有在一些宏观的方法论下去训练&#xff0c;读的时候能感觉出一些科研的套路&#xff0c;论文写作的套路&#x…

C++算法:图中的最短环

题目 现有一个含 n 个顶点的 双向 图&#xff0c;每个顶点按从 0 到 n - 1 标记。图中的边由二维整数数组 edges 表示&#xff0c;其中 edges[i] [ui, vi] 表示顶点 ui 和 vi 之间存在一条边。每对顶点最多通过一条边连接&#xff0c;并且不存在与自身相连的顶点。 返回图中 …

Kafka保证消息幂等以及解决方案

1、幂等的基本概念 幂等简单点讲&#xff0c;就是用户对于同一操作发起的一次请求或者多次请求的结果是一致的&#xff0c;不会产生任何副作用。幂等分很多种&#xff0c;比如接口的幂等、消息的幂等&#xff0c;它是分布式系统设计时必须要考虑的一个方面。 查询操作(天然幂等…

【VR开发】【Unity】0-课程简介和概述

【说明】 这是我录制的一套VR基础开发课程的文字版本&#xff0c;更加便于快速参考。 应大家在后台所提的需求&#xff0c;从今天开始&#xff0c;我计划带给大家一套完整达40课时的VR开发基础课程。 在开始学习前需要注意如下几点&#xff1a; 本教程基于Unity2022.2.1f1版…

SqlServer安装教程

百度网盘地址: 链接&#xff1a;https://pan.baidu.com/s/1ntqoK9uVc6fBVTm7twh8kw 提取码&#xff1a;grdt 安装: 双击:SQLEXPRADV_x64_CHS.exe ,等待;点击计划,系统配置检查器,根据要求修改(我被要求重启了)点击安装,全新SQL Server独立安装或向现有安装添加功能,接受功能选…

2023年09月 C/C++(七级)真题解析#中国电子学会#全国青少年软件编程等级考试

C/C编程&#xff08;1~8级&#xff09;全部真题・点这里 Python编程&#xff08;1~6级&#xff09;全部真题・点这里 第1题&#xff1a;红与黑 有一间长方形的房子&#xff0c;地上铺了红色、黑色两种颜色的正方形瓷砖。你站在其中一块黑色的瓷砖上&#xff0c;只能向相邻的黑色…

线性筛的简单证明

原理 线性筛是一种可以在线性时间内将素数筛选出来的算法&#xff0c;其中的主要思想在于保证合数只会被它的最小质因数筛掉并且筛掉一次。 代码 下面是线性筛的算法CPP实现&#xff1a; vector<int> generate_primes_linear_time(int n) {vector<int> lp(n 1…