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备份了全库内容,但是我只想恢复某一张表,怎么办的主要内容,如果未能解决你的问题,请参考以下文章
Linux/Windows下MySQL数据库的备份与还原(mysqldump)