從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所以導入時會報錯可以忽略

導入報錯可以忽略

 


如果數據不大,也可以將某個庫先恢復操作,在單獨將某個表備份,在恢復某個表
 
轉自
http://blog.itpub.net/30345407/viewspace-2123125/


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM