Mysql数据库mys和ora库的备份与恢复脚本
!/bin/bash
Time=$(date +%Y%md%H%M%S)
Back_dir="$HOME/mysqlback/${Time}"
function Detect_u_p {
read -p "输入数据库用户名和密码,用空格分隔:" user passwd
mysql -u${user} -p{passwd} -e "show databases" &>/dev/null
[ $? -eq 0 ] && return 0 || return 1
}
function backup {
Detect_u_p
if [ $? -eq 0 ];then
Back_db=($(mysql -u${user} -p{passwd} -e "show databases" 2>/dev/null | awk '/^mys|ora/ {print $1}'))
[ ! -d ${Back_dir} ] && mkdir -p ${Back_dir}
echo "${Time}开始备份"
for back_db in ${Back_db[*]}
do
mysqldump -u${user} -p{passwd} --opt -R ${back_db} > ${Back_dir}/${back_db}.sql &>/dev/null
echo "${back_db}备份完成"
done
mysqldump -u${user} -p{passwd} --opt -R --all-databases --routines > ${Back_dir}/alldb_back.sql &>/dev/null && echo "整库备份完成"
else
echo "用户名或密码输入错误"
fi
}
function imp_db {
Del_db=($(mysql -u${user} -p{passwd} -e "show databases" 2>/dev/null | awk '/^mys|ora/ {print $1}'))
for del_db in ${Del_db[*]}
do
mysql -u${user} -p{passwd} -e "DROP DATABASE ${del_db}" &>/dev/null
done
Rec_db=($(ls -l $1 | egrep -v "总用量|alldb" | awk '{print $9}' | awk -F"." '{print $1}'))
for rec_db in ${Rec_db[*]}
do
mysql -u${user} -p{passwd} -e "CREAT DATABASE ${rec_db}" &>/dev/null && mysql -u${user} -p{passwd} ${rec_db} < $1/{rec_db}.sql &>/dev/null && echo "恢复${rec_db}成功"
done
}
function recover {
Rec_dir=$(find $HOME -type d -name mysqlback)
if [ ! -d ${Rec_dir} ];then
echo "未找到脚本备份的目录"
else
ls -lt {Rec_dir} | egrep -v "总用量" | awk -v Dir="${Rec_dir}" 'BEGIN {print "备份路径为:"} $9 ~ /[0-9]+/ {print NR"."Dir"/"$9}'
Dir_arr=($(ls -lt {Rec_dir} | awk -v Dir="${Rec_dir}" '$9 ~ /[0-9]+/ {print Dir"/"$9}'))
read -p "选择目录为${Dir_arr[0]}中的文件来恢复数据库?(y or n):" yn
if [ "$yn" = "y" -o "$yn" = "Y" -o "$yn" = "yes" ];then
Detect_u_p
[ $? -eq 0 ] && imp_db ${Dir_arr[0]} || echo "用户名或密码输入错误"
else
read -p "用其他备份目录来恢复数据库,请输入对应序号:" digit
if [ ${digit} -gt 0 -a ${digit} -le ${#Dir_arr[*]} ];then
digit=$((${digit}-1))
imp_db ${Dir_arr[${digit}]}
else
echo "输入错误"
fi
fi
fi
}
while [ 1 ]
do
echo -e "1.备份数据库!\n2.恢复数据库!"
read -p "请输入要实现功能的序号:" choice
echo "********************************************************"
case ${choice} in
1) backup;;
2) recover;;
) echo "Byebye!"
exit 1
esac
echo "*******************************************************"
read -p "Continue?(y or n):" yn
[ "$yn" = "y" -o "$yn" = "Y" ] && continue || break
done
Mysql数据库mys和ora库的备份与恢复脚本的更多相关文章
- 第一篇:操纵MySQL数据库(1) - 基于MySQLdb库
前言 本文讲解在Python语言中使用MySQLdb库操纵MySQL数据库的方法. 准备工作 1. 安装Python和MySQL2. 安装MySQLdb (exe下载地址:http://sourcef ...
- MySQL数据库(2)- 库的操作、表的操作、数据的操作、存储引擎的介绍
一.库的操作 1.系统数据库 执行如下命令,查看系统数据库: mysql> show databases; 参数解释: information_schema: 虚拟库,不占用磁盘空间,存储的是数 ...
- MySQL数据库(二)--库相关操作、表相关操作(1)、存储引擎、数据类型
一.库相关操作 1.创建数据库 (1)语法 create database 数据库 charset utf8; (2)数据库命名规范 可以由字母.数字.下划线.@.#.$ 区分大小写 唯一性 不能使用 ...
- MySQL数据库(二)——库相关操作、表相关操作(一)、存储引擎、数据类型
库相关操作.表相关操作(一).存储引擎.数据类型 一.库相关操作 1.创建数据库 (1)语法 create database 数据库 charset utf8; (2)数据库命名规范 可以由字母.数字 ...
- mysql数据库-初始化sql建库建表-关联查询投影问题
下面是一个简易商城的几张表的创建方式 drop database if exists shop ; create database shop CHARACTER SET 'utf8' COLLATE ...
- MySQL数据库入门(建库和建表)--陈远波
建库.建表 1.建库 (1)SQL语句命令建库: Create database数据库名称 (该方法创建的数据库没有设置编码乱码) 1 2 3 4 5 -- 创建数据库时,设置数据库的编码方式 -- ...
- MySQL数据库中统计一个库中的所有表的行数?
今天公司两个远端的数据库主从同步有点问题,查看下wordpress库下所有表的表的条目? mysql> use information_schema;Database changedmysql& ...
- mysql数据库之表和库
SQL:语句主要用于存储数据,查询数据,更新数据和管理关系数据库系统SQL语言有IBM开发,sql语言分为中类型: 1.DDL语句 数据库定义语句:数据库,表,视图,索引,存储过程,例如create, ...
- MySQL数据库---库的操作
MySQL数据库中,以库,表,记录的形式管理所有的数据,安装MySQL数据库的服务器上可以包含多个库,一个库中包含多张表,一张表中包含多条记录.库对应的是文件系统中文件夹的概念,表对应的是文件的概念, ...
随机推荐
- eclipse中Maven项目pom.xml报错:com.thoughtworks.xstream.io.HierarchicalStreamDriver
eclipse中创建Maven项目时 pom.xml报错:com.thoughtworks.xstream.io.HierarchicalStreamDriver 解决方案1.在pom文件中加入mav ...
- java——对象学习笔记
1.面向对象(OOP)的三大特性 对象的行为(behavior):可以对对象施加哪些操作,或者可以对对象施加哪些方法. 对象的状态(state):当施加那些方法后,对象如何响应. 对象标识(ident ...
- redis基本类型和使用
redis存储数据的基本类型有:string(字符串类型).hash(散列类型).list(列表类型).set(集合类型).zset(有序集合类型). 依次做一些练习.redis命令不区分大小写. k ...
- IE浏览器清除缓存没用
再想买更新JS和css文件之后, 使用 internet 里面的删除选项 发现样式和事件还是没用变 最终发现 需要 按 f12 找到这个清缓存才正常解决问题
- 笔记:I/O流-ZIP文档
ZIP文档以压缩格式存储了一个或多个文件,每个ZIP文档都有一个头,包含诸如每个文件名字和所使用的压缩方法等信息,在 Java 中可以使用 ZipInputStream 来读入ZIP 文档,getNe ...
- 笔记:Hibernate SQL 查询
Hibernate 支持使用原生的SQL查询,使用原生SQL查询可以利用某些数据库特性,原生SQL查询也支持将SQL语句放在配置文件中配置,从而提高程序的解耦,命名SQL查询还可以用于调用存储过程. ...
- 基于TODO的开发方法
之前买了一本书,叫<架构探险-从零开始写Java Web框架 >(不推荐购买-),一本标题党书籍!但是我很推崇作者写代码的方式,就是基于TODO的方式进行开发! 个人认为以基于TODO的方 ...
- nuxt 的一些报错和插件推荐
1.项目有启动报这个错误的,是因为node版本太低了,nuxt要求node版本要达到8.0.0以上 . 2.插件推荐
- Konckout第四个实例:组合类型数据绑定 -- 日期双向绑定显示
<!doctype html> <html > <head> <meta http-equiv="Content-Type" conten ...
- 透析thinkphp5升级版开发框架tpframe
这里将全面的介绍这个框架给我们开发带来的好处,让你们对它有更深层次的认识,喜欢或不喜欢的,欢迎大家前来留言讨论 一.目录层次结构 现在很多的项目,特别是大一点的项目里面,都会有很多的人参与,要进行程序 ...