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

avatar 2023年5月18日18:25:25 评论 312 次浏览

在工作中针对数据库的导入导出,备份恢复等等经常会遇到,但是如果在工作的过程中,数据库不小心被人删除了,那该怎么办,我们需要先在备份中直接恢复,也可以从MySQL全库备份中恢复某个库和某张表,下面看一下恢复的方法

一、全库备份-A

[root@www.wulaoer.org 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@www.wulaoer.org backup]#  mysql -uroot -p123456 report --one-database <fulldump.sql

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

三、从全备份中只恢复t_order表 1)从备份查询恢复表的表结构

[root@www.wulaoer.org 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@www.wulaoer.org backup]# grep 'INSERT INTO `t_order`' fulldump.sql >data.sql

也可以将某个库先恢复操作,在单独将某个表备份,在恢复某个表,不过这种方式比较繁琐一点,根据自己的喜好自己选择吧。

avatar

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: