linux mysql中我用mysqldump备份了全库内容,但是我只想恢复某一张表,怎么办

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux mysql中我用mysqldump备份了全库内容,但是我只想恢复某一张表,怎么办相关的知识,希望对你有一定的参考价值。

这个问题不是mysql数据库方面的问题,而是如何从一个文本文件中取出需要的部分内容的问题。 从数据库角度来说,没有什么好办法,可以使用操作系统中的文本编辑处理工具来实现。例如,如果不是太大,几百M可以用editplus,ultraedit等编辑工具打开找你需要sql拷贝出来导入。

如果是linux/unix,可参考如下方法:

1.使用 awk:
可以先到原数据库中使用 \'show tables;\' 查看数据库表的列表,注意,此列表已经按照字母排序,例如:
table1

table2
table3
然后使用awk 来过滤sql语句,假设你要恢复 table2 表,可以使用下面的语句:
awk ‘/^-- Table structure for table .table2./,/^-- Table structure for table .table3./print’ mydumpfile.sql > /tmp/recovered_table.sql

2.使用sed:
与上面类似,假设你要恢复 table2 表,可以使用下面的语句:
cat mydumpfile.sql | sed -n -e \'/Table structure for table .test1./,/Table structure for table .test2./p\' > /tmp/extracted_table.sql
参考技术A 看不懂,没用,机都开不了,还备份 参考技术B ……

Linux中使用mysqldump对MySQL数据库进行定时备份

    #!/bin/bash   
    PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin   
    export PATH   
    export LANG=en_US.UTF-8  
    savedir=/log/database_bak/   
    cd "$savedir"  
    time="$(date +"%Y-%m-%d %H:%M:%S")"  
    mysqldump -u [my_user] -p[my_pwd] [db_name] > [db_name]-"$time".sql  

这里注意以下-p后面没有空格直接加[my_pwd]

然后该sh脚本放入/log/sh/目录下并赋予执行权限,最后进入linux定时任务crond,加入以下脚本:

    # run-parts 每天5点02分执行databasebak.sh   
    01 * * * * root run-parts /etc/cron.hourly   
    02 4 * * * root run-parts /etc/cron.daily   
    22 4 * * 0 root run-parts /etc/cron.weekly   
    42 4 1 * * root run-parts /etc/cron.monthly   
    02 5 * * * root sh /log/sh/databasebak.sh  

最后保存好后重启crond,service crond restart即可!

以上是关于linux mysql中我用mysqldump备份了全库内容,但是我只想恢复某一张表,怎么办的主要内容,如果未能解决你的问题,请参考以下文章

mysql备份之mysqldump工具

Linux/Windows下MySQL数据库的备份与还原(mysqldump)

Linux中使用mysqldump对MySQL数据库进行定时备份

Linux备份数据库,mysqldump命令实例详解

linux系统下mySQL数据库 备份方法和脚本?

Linux中使用mysqldump对MySQL数据库进行定时备份