mysql 遍历所有的库并根据表和sql语句备份
建库、用户语句
create database test_hb;
create user ' test_hb'@'%' identified by '123456';
grant all privileges on test_hb.* to ' test_hb'@'%';
grant all privileges on test_hb.* to test_hb@localhost identified by '123456';
flush privileges;
备份脚本
#!/bin/sh # $Id: mysql_backup # define restricted path
PATH="/bin:/usr/bin:/sbin:/usr/sbin:/usr/local/mysql3306/bin" # adirname - return absolute dirname of given file
adirname() { odir=`pwd`; cd `dirname $1`; pwd; cd "${odir}"; } # ---------
# constants
# ---------
MYNAM=`basename "$0"`
MYDIR=`adirname "$0"`
MYTMP="${MYDIR}/tmp"
MYLCK="${MYTMP}/${MYNAM}.lock" MYPRG="/usr/local/mysql3306/bin/mysql -uroot -p123456 -P 3306 -h 127.0.0.1 --local-infile=1 -Bse" # mysql client
MYDMP="/usr/local/mysql3306/bin/mysqldump -uroot -p123456 -P 3306 -h 127.0.0.1 -Q -R -v --opt" # mysqldump
ROTATE=`date +%d`
MYBAK="/home/backup/mysql/${ROTATE}" # destination dir
DT="" # ---------
# functions
# --------- message() { echo "$@"; } # message - output message on stdout
error() { echo "$@" >&2; } # error - output message on stderr
die() { error "$@"; exit 1; } # die - output message on stderr and exit usage() {
error "Usage: ${MYNAM} <options>"
error ""
error "Available options:"
error ""
error " -h This help screen"
error ""
error " -q suppress non-error messages"
error " -d db1,db2,... To dump several databases."
error " -t File name with datetime"
error " -p path Dump to the directory" die
} # parse command line options
while getopts d:p:hqt opt; do
case "${opt}" in
q)
V='-q'
;;
t)
DT=".`date +%Y%m%d%H%M`"
;;
p)
DP=${OPTARG}
;;
d)
DBS=(${OPTARG//,/ })
;;
h)
usage
;;
*)
usage
;;
esac
done [ -n "${DP}" ] && MYBAK="${DP}" if [ ! -d ${MYTMP} ] ; then
mkdir -p ${MYTMP}
fi if [ ! -d ${MYBAK} ] ; then
mkdir -p ${MYBAK}
fi # ----
# main
# ---- # perform some locking (as good as it gets in a shell)
[ -s "${MYLCK}" ] && kill -0 `cat "${MYLCK}"` 2>/dev/null &&
die "${MYNAM}: already running!"
echo "$$" > "${MYLCK}" # get list of databases
mydbs=""
if [ "x$DBS" == "x" ] ; then
mydbs=`${MYPRG} "SHOW DATABASES"`
[ -z "${mydbs}" ] && die "${MYNAM}: unable to get list of databases."
else
S=0
E=${#DBS[@]}
while [ ${S} -lt ${E} ]
do
mydb=`${MYPRG} "SHOW DATABASES like \"${DBS[${S}]}\""`
if [ -z "${mydb}" ] ; then
DBS[${S}]=""
else
mydbs=${mydbs}" "${mydb}
fi
S=`expr ${S} + 1`
done
fi # process databases
for db in ${mydbs}; do # skip special database(s)
[ "$db" == "information_schema" ] && continue
[ "$db" == "test" ] && continue
[ "$db" == "car_source" ] && continue # verbose?
[ "$V" == "-q" ] || echo "Processing database ${db}..."
[ "$V" == "-q" ] || echo # make dir
mkdir -p "${MYBAK}/${db}" ${MYDMP} "${db}" 2>"${MYBAK}/${db}/${db}${DT}.log" | gzip > "${MYBAK}/${db}/${db}${DT}.sql.gz" # get list of tables
mytbs=`${MYPRG} "SHOW TABLES FROM \\\`${db}\\\`"`
[ -z "${mytbs}" ] && message "${MYNAM}: unable to get list of tables for ${db}." # process tables
for tb in ${mytbs}; do
# MYTIME=`date +%Y%m%d%H%M`
[ "$V" == "-q" ] || echo "Processing ${db}.${tb}..." [ "$V" == "-q" ] || echo "- Dumping..."
${MYDMP} "${db}" "${tb}" 2>"${MYBAK}/${db}/${db}.${tb}${DT}.log" | gzip > "${MYBAK}/${db}/${db}.${tb}${DT}.sql.gz" [ "$V" == "-q" ] || echo "- Checking..."
${MYPRG} "CHECK TABLE \`${db}\`.\`${tb}\`" | egrep "[^:alnum:\._-]error[^:alnum:\._-]" |
grep -v "doesn't support check" [ "$V" == "-q" ] || echo "- Analyzing..."
${MYPRG} "ANALYZE LOCAL TABLE \`${db}\`.\`${tb}\`" > /dev/null [ "$V" == "-q" ] || echo "- Optimizing..."
${MYPRG} "OPTIMIZE LOCAL TABLE \`${db}\`.\`${tb}\`" > /dev/null [ "$V" == "-q" ] || echo
done # verbose?
[ "$V" == "-q" ] || echo done # cleanup
touch -t `/bin/date --date "3 days ago" "+%Y%m%d%H%M"` /dev/shm/${MYNAM}.start
find /home/backup/mysql/ ! -newer /dev/shm/${MYNAM}.start -type f -exec rm {} \;
find /home/backup/mysql/ -type d -empty -print0 | xargs -0 -n 100 rm -rf &> /dev/null
还原数据库时,到备份目录找到最新的备份。dataname.sql.gz 结尾
zcat dataname.sql.gz|mysql -uroot -p123456 dataname
mysql 遍历所有的库并根据表和sql语句备份的更多相关文章
- mysql从一个表中拷贝数据到另一个表中sql语句
这一段在找新的工作,今天面试时,要做一套题,其中遇到这么一句话,从一个表中拷贝所有的数据到另一个表中的sql是什么? 原来我很少用到,也没注意过这个问题,面试后我上网查查,回来自己亲手写了写,测试了下 ...
- MySQL创建民族表的SQL语句
MySQL创建民族表的SQL语句 CREATE TABLE `nation` ( `id` ) unsigned NOT NULL AUTO_INCREMENT, `nation` ) NOT NUL ...
- MySql update inner join!MySql跨表更新 多表update sql语句?如何将select出来的部分数据update到另一个表里面?
项目中,评论数,关注数等数据,是实时更新的.+1,-1 这种. 有的时候,可能统计不准确. 需要写一个统计工具,更新校准下. 用Java写SQL和函数,代码很清晰,方便扩展,但是太慢了. 为了简单起见 ...
- MySQL数据库-表操作-SQL语句(一)
1. 数据库操作与存储引擎 1.1 数据库和数据库对象 数据库对象:存储,管理和使用数据的不同结构形式,如:表.视图.存储过程.函数.触发器.事件等. 数据库:存储数据库对象的容器. 数据库分两种 ...
- phpmyadmin查看创建表的SQL语句
本人菜鸟 发现创建表的SQL语句还不会 直接phpmyadmin解决的 查看见表的语句除了直接到处SQL格式文件 打开查看外 就是执行语句查询 语句:show create table 表名 貌似大 ...
- 创建数据库和表的SQL语句
创建数据库的SQL语句: 1 create database stuDB 2 on primary -- 默认就属于primary文件组,可省略 3 ( 4 /*--数据文件的具体描述--*/ 5 n ...
- 创建数据库和表的SQL语句【转】
创建数据库和表的SQL语句 转至http://www.cnblogs.com/philanthr/archive/2011/08/09/2132398.html 创建数据库的SQL语句: 1 crea ...
- oracle 修改表的sql语句
oracle 修改表的sql语句 1增加一个列:ALTER TABLE 表名 ADD(列名 数据类型);如:ALTER TABLE emp ADD(license varchar2(256)) ...
- (转载)根据数据字典表定义的表结构,生成创建表的SQL语句
<来源网址:http://www.delphifans.com/infoview/Article_221.html>根据数据字典表定义的表结构,生成创建表的SQL语句 //1. 类名:T ...
随机推荐
- 67 个JavaScript和CSS实用工具、库与资源
在这篇文章中,我不会与大家谈论大型的前端框架,如 React.Angular.Vue 等,也没有涉及那些流行的代码编辑器,如 Atom.VS Code.Sublime,我只想与大家分享一个有助于提升开 ...
- 微信小程序——demo合集及简单的文档解读【五】
官方Demo https://github.com/wechat-miniprogram/miniprogram-demo 其他Demo https://www.cnblogs.com/ytkah/p ...
- 图片文字识别aip的一个小Demo
目前接触到了一个新的内容,识别图片上的文字,以下是这个Demo 首先需要在需要在百度云-管理中心创建应用 地址:http://console.bce.baidu.com/ai/#/ai/ocr/app ...
- 【XSY2716】营养餐 博弈论
题目描述 给你一棵有根树,每个点有两个属性\(a,b\) 两人轮流操作,每次要减小一个点的\(a\)值,要求 \[ a_x\geq\sum_{i\in child(x)}a_ib_i \] 保证初始状 ...
- Js点击触发Css3的动画Animations、过渡Transitions效果
关键是首先指定动画效果的CSS属性名称,然后在Js中改变这个属性 如果不使用Js触发,可以选择利用css的状态:hover,focus,active 来触发,也可以一开始就触发 下例为Js点击触发过渡 ...
- MT【298】双参数非齐次
若函数$f(x)=x^2+(\dfrac{1}{3}+a)x+b$在$[-1,1]$上有零点,则$a^2-3b$的最小值为_____ 分析:设零点为$x_0$,则$b=-x^2_0-(\dfrac{1 ...
- [POJ 1637] Sightseeing tour(网络流)
题意 (混合图的欧拉回路判定) 给你一个既存在有向边, 又存在无向边的图. 问是否存在欧拉回路. \(N ≤ 200, M ≤ 1000\) 题解 难点在于无向边. 考虑每个点的度数限制. 我们先对无 ...
- 【dfs】P1331 海战
题目描述 在峰会期间,武装部队得处于高度戒备.警察将监视每一条大街,军队将保卫建筑物,领空将布满了F-2003飞机.此外,巡洋船只和舰队将被派去保护海岸线.不幸的是因为种种原因,国防海军部仅有很少的几 ...
- uvaLive6837 ThereIsNoAlternative (kruskal)
题意:给一个联通图,求出不可替代的边,即存在于所有最小生成树中的边,的数量和它们边权之和 首先kruskal跑出一个最小生成树,枚举其中所有的边,若把这条边去掉以后再跑kruskal答案不是最小,则这 ...
- 【mysql】工作中mysql常用命令及语句
1.查看mysql版本号 MySQL [release_test_oa]> select version(); +------------+ | version() | +----------- ...