从全量备份的sql文件中 恢复单表 全库备份恢复单张表

本文介绍如何从全量备份的SQL文件中恢复单张表,包括分离创建表语句及插入数据语句的方法,并演示了具体的恢复步骤。

从全量备份的sql文件中 恢复单表

一文搞懂MySQL数据库怎么备份与恢复
https://www.uoften.com/article/226599.html
MySQL数据库备份与恢复
https://blog.youkuaiyun.com/akfeu48868/article/details/102246959/

3.4 从单库备份中恢复单表
这个需求还是比较常见的。比如说我们知道哪个表误操作了,那么就可以用单表恢复的方式来恢复。

举例:我们有atguigu整库的备份,但是由于class表误操作,需要单独恢复出这张表。

cat atguigu.sql | sed -e '/./{H;$!d;}' -e 'x;/CREATE TABLE `class`/!d;q' > class_structure.sql 
cat atguigu.sql | grep --ignore-case 'insert into `class`' > class_data.sql 
#用shell语法分离出创建表的语句及插入数据的语句后 再依次导出即可完成恢复 

use atguigu; 
mysql> source class_structure.sql; 
Query OK, 0 rows affected, 1 warning (0.00 sec) 

mysql> source class_data.sql; 
Query OK, 1 row affected (0.01 sec)
在使用 **华为 GaussDB**(或 openGauss)数据库时,进行库备份通常有以下几种方式:逻辑备份(如 `gs_dump`、`gs_dumpall`)和物理备份(通过底层文件复制,需配合工具或脚本)。下面重点介绍常用的**逻辑备份语句**,适用于 GaussDB T / DWS / openGauss 等版本。 --- ### ✅ 一、备份单个数据库(推荐:gs_dump) #### 1. 备份整个数据库(结构 + 数据) ```bash gs_dump -h 127.0.0.1 -p 5432 -U username -f /path/to/backup.sql -F plain mydb ``` - `-h`:数据库主机 - `-p`:端口 - `-U`:用户名 - `-f`:输出文件路径 - `-F`:格式,可选: - `plain`:纯 SQL 脚本(默认) - `custom`:二进制格式,支持压缩和选择性恢复 - `directory`:目录格式,适合大库 - `tar`:tar 格式 > 示例:导出为自定义格式(压缩备份) ```bash gs_dump -h 127.0.0.1 -p 5432 -U omm -F custom -f /backup/mydb_backup.dmp mydb ``` --- ### ✅ 二、备份指定 #### 1. 备份单张 ```bash gs_dump -h 127.0.0.1 -p 5432 -U username -t schema_name.table_name -f /path/to/table_backup.sql mydb ``` > 示例:备份 `public.users` ```bash gs_dump -h localhost -p 5432 -U omm -t public.users -F plain -f /backup/users.sql mydb ``` #### 2. 备份 ```bash gs_dump -h localhost -p 5432 -U omm -t public.users -t public.orders -f /backup/two_tables.sql mydb ``` --- ### ✅ 三、仅备份结构或数据 | 选项 | 说明 | |------|------| | `-s` 或 `--schema-only` | 只导出结构(不含数据) | | `-a` 或 `--data-only` | 只导出数据(不含结构) | #### 示例:只备份结构 ```bash gs_dump -h localhost -p 5432 -U omm -s -f /backup/schema_only.sql mydb ``` #### 示例:只备份数据 ```bash gs_dump -h localhost -p 5432 -U omm -a -f /backup/data_only.sql mydb ``` --- ### ✅ 四、全量备份所有数据库(gs_dumpall) 适用于需要备份 **所有数据库** 和 **全局对象**(如用户、角色等) ```bash gs_dumpall -h 127.0.0.1 -p 5432 -U omm -f /backup/full_backup.sql ``` > 包含 CREATE USER、DATABASE 等语句,适合做整库迁移或灾备。 --- ### ✅ 五、恢复备份文件 #### 1. 恢复 plain 格式 SQL ```bash gsql -d mydb -U omm -f /backup/backup.sql ``` #### 2. 恢复 custom 格式 ```bash gs_restore -d mydb /backup/mydb_backup.dmp ``` --- ### ✅ 六、常用参数总结 | 参数 | 含义 | |------|------| | `-f file` | 输出到指定文件 | | `-F format` | 输出格式(p=plain, c=custom, d=directory, t=tar) | | `-t table` | 指定名(支持模式名) | | `-s` | 仅结构 | | `-a` | 仅数据 | | `-C dbname` | 在 dump 前先连接到该数据库 | | `--exclude-table` | 排除某些 | --- ### 🔐 注意事项 1. 执行备份的用户需要具有相应数据库的 `CONNECT` 和 `SELECT` 权限。 2. 建议在低峰期执行大规模备份。 3. 对于生产环境,建议结合脚本+定时任务(如 crontab)实现自动备份。 4. GaussDB 集群环境需确保主节点执行备份。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值