shell在指定目录下批量执行sql脚本的实例

 更新时间:2018年06月19日 14:12:11   作者:lihengfang  
今天小编就为大家分享一篇shell在指定目录下批量执行sql脚本的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

如下所示:

#!/bin/bash
#execute all script in specified directory
MYDATE=`date +%F'-'%T'-'%w`
MYSQL_PATH=/tmp/scripts #指定的目录
LOG_FILE=/tmp/scripts/exec_${MYDATE}.log
confirm=
db_name=
db_pass=
for file in ${MYSQL_PATH}/*
do
if [ -f "$file" ] ; then
postfix=`echo $file | awk -F'.' '{print "."$NF}'`
 if [ $postfix = ".sql" ] ; then
  if [ ! $db_name ] ; then #如果没有指定数据库
  read -p "请输入数据库名:" db_name
  read -p "你输入的数据名是【$db_name】,确认继续请输入--yes--: " confirm
  fi
  if [ "$confirm" = "yes" ] && [ -n $confirm ] ; then
  if [ ! $db_pass ] ; then #如果没有设置密码
   stty -echo #密码输入保护关闭显示
   read -p "请输入数据库密码:" db_pass
   echo -e "\n"
   stty echo
  fi
  mysql -uroot -p$db_pass -P3306 --default-character-set=utf8 ${db_name} < $file >& error.log
  echo $file 
  echo -e "\n===========$file=============\n" >>${LOG_FILE}
  cat error.log >>${LOG_FILE} #输出执行日志
  error=`grep ERROR error.log` #读取错误日志信息
  if [ -n "$error" ] ; then #如果有错误就退出程序
   echo $error
   exit
  fi
  else
  echo "您已经取消操作!"
  exit
  fi
 fi
fi
done

以上这篇shell在指定目录下批量执行sql脚本的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Window11 WSL2 添加静态IP的脚本

    Window11 WSL2 添加静态IP的脚本

    这篇文章主要介绍了Window11 WSL2 添加静态IP的脚本方法,通过一段脚本给 Windows 端的"vEthernet (WSL)"加了IPv4 172.18.16.1,给 Linux 端的 eth0 添加 IPv4 172.18.16.1,在使用前,请按需调整网络接口的名称和IP地址,需要的朋友可以参考下
    2023-01-01
  • 解决VirtualBox中Ubuntu 14.04屏幕分辨率不能设置的问题

    解决VirtualBox中Ubuntu 14.04屏幕分辨率不能设置的问题

    下面小编就为大家带来一篇解决VirtualBox中Ubuntu 14.04屏幕分辨率不能设置的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • Shell脚本经典之Fork炸弹的分析与预防

    Shell脚本经典之Fork炸弹的分析与预防

    这篇文章主要给大家介绍了Shell脚本经典之Fork炸弹的分析与预防,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
    2017-06-06
  • shell中的数组操作小结和冒泡排序实现脚本分享

    shell中的数组操作小结和冒泡排序实现脚本分享

    这篇文章主要介绍了shell中的数组操作小结和冒泡排序实现脚本分享,需要的朋友可以参考下
    2014-12-12
  • Linux基础命令日常积累

    Linux基础命令日常积累

    Linux命令虽然用处很多,用过这么多次但是对其步骤、命令还是不记得,每次还是要到处找资料,下面小编把本次linux生产环境搭建分享在脚本之家平台,供大家参考
    2015-10-10
  • 利用Linux中的crontab实现分布式项目定时任务功能

    利用Linux中的crontab实现分布式项目定时任务功能

    crond是Linux用来定期执行程序的命令.这篇文章主要介绍了利用Linux中的crontab实现分布式项目定时任务,需要的朋友可以参考下
    2018-01-01
  • Shell 命令替换的两种方式

    Shell 命令替换的两种方式

    这篇文章主要介绍了Shell 命令替换的两种方式,需要的朋友可以参考下
    2014-04-04
  • 详解Shell编程之变量数值计算(二)

    详解Shell编程之变量数值计算(二)

    本篇文章主要介绍了详解Shell编程之变量数值计算(二),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-02-02
  • linux shell脚本学习xargs命令使用详解

    linux shell脚本学习xargs命令使用详解

    xargs是一条Unix和类Unix操作系统的常用命令。它的作用是将参数列表转换成小块分段传递给其他命令,以避免参数列表过长的问题
    2013-12-12
  • shell自动安装python3的脚本写法

    shell自动安装python3的脚本写法

    这篇文章主要介绍了shell自动安装python3的脚本写法,本文给大家提到了shell脚本一键安装python3+pip的方法,需要的朋友可以参考下
    2019-12-12

最新评论