从MySQL全库备份中恢复某个库和某张表【转】

从MySQL全库备份中恢复某个库和某张表




一、全库备份-A


[root@mha2 backup]#mysqldump -uroot -p123456 --default-character-set=utf8 --single-transaction --extended-insert=false --hex-blob --master-data=2 --log-error=/tmp/test.err --routines --triggers --events --quick --flush-logs --all-databases > fulldump.sql




二、从全备份中只恢复report库


[root@mha2 backup]#  mysql -uroot -p123456 report --one-database <fulldump.sql


可以看出这里主要用到的参数是--one-database简写-o的参数,极大方便了我们的恢复灵活性。


三、从全备份中只恢复t_order表
1)从备份查询恢复表的表结构
[root@mha2 backup]# sed -e'/./{H;$!d;}' -e 'x;/CREATE TABLE `t_order`/!d;q' fulldump.sql 


DROP TABLE IF EXISTS `t_order`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `t_order` (
  `c_date` varchar(30) DEFAULT NULL,
  `order_no` varchar(40) DEFAULT NULL,
  `key_info` varchar(200) DEFAULT NULL,
  `flag` varchar(30) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;


2)从备份查询出表的表数据
[root@mha2 backup]# grep 'INSERT INTO `t_order`' fulldump.sql >data.sql

总结
比如恢复tb1表数据
sed -e'/./{H;$!d;}' -e 'x;/CREATE TABLE `tb1`/!d;q' 20180723.sql > tb1.sql
grep 'INSERT INTO `tb1`' 20180723.sql >> tb1.sql

或者

sed -n -e '/CREATE TABLE.*`tb1`/ ,/UNLOCK TABLES/p' 20180723.sql > tb_1.sql
 
但是这样导出来的文件会有SET character_set_client所以导入时会报错可以忽略

导入报错可以忽略

 

如果导入时有主键报错

SET foreign_key_checks = 0; 禁用外键

SOURCE dump_file_name;      进行SQL查询

SET foreign_key_checks = 1; 恢复外键


如果数据不大,也可以将某个库先恢复操作,在单独将某个表备份,在恢复某个表
 
转自
http://blog.itpub.net/30345407/viewspace-2123125/
posted @   paul_hch  阅读(6030)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示