mysql dump 40101_如何从mysqldump产生的全库备份中只恢复某一个库、某一张表?

一、全库备份-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

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

三、从全备份中只恢复t_order表

1)从备份查询恢复表的表结构

[root@mha2 backup]# sed -e'/./{H;$!d;}' -e 'x;/CREATE TABLE `t_order`/!d;q' fulldump.sqlDROP 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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值