• 从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/
  • 相关阅读:
    [BZOJ3535][Usaco2014 Open]Fair Photography
    [LOJ#2270][BZOJ4912][SDOI2017]天才黑客
    [UOJ#122][NOI2013]树的计数
    [BZOJ4816][Sdoi2017]数字表格
    [BZOJ2154]Crash的数字表格
    [BZOJ3529][Sdoi2014]数表
    [BZOJ2820]YY的GCD
    [BZOJ2301][HAOI2011]Problem b
    [UOJ#223][BZOJ4654][Noi2016]国王饮水记
    [BZOJ4653][Noi2016]区间
  • 原文地址:https://www.cnblogs.com/paul8339/p/6203993.html
Copyright © 2020-2023  润新知