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脚本的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Shell中处理包含空格的文件名实例

    Shell中处理包含空格的文件名实例

    这篇文章主要介绍了Shell中处理包含空格的文件名实例,需要的朋友可以参考下
    2014-05-05
  • HBASE 常用shell命令,增删改查方法

    HBASE 常用shell命令,增删改查方法

    今天小编就为大家分享一篇HBASE 常用shell命令,增删改查方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-06-06
  • Shell脚本传递参数的4种方式实例说明

    Shell脚本传递参数的4种方式实例说明

    Shell脚本是一种命令语言,可以用于自动化执行各种任务,在脚本中,我们可以通过参数来传递信息,本文将介绍如何在shell脚本中传递参数,包括位置参数、特殊变量、环境变量和命名参数,需要的朋友可以参考下
    2023-06-06
  • Shell脚本实现批量添加用户

    Shell脚本实现批量添加用户

    这篇文章主要介绍了Shell脚本实现批量添加用户,本文使用最简单的方法实现了指添加用户,需要的朋友可以参考下
    2014-12-12
  • Linux Shell 自动交互功能实现

    Linux Shell 自动交互功能实现

    本文主要介绍了Linux Shell 自动交互功能实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • Shell脚本用for循环遍历参数的方法技巧

    Shell脚本用for循环遍历参数的方法技巧

    今天小编就为大家分享一篇关于Shell脚本用for循环遍历参数的方法技巧,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • linux查看目录的四种方法(ls只显示目录)

    linux查看目录的四种方法(ls只显示目录)

    linux如何只列出目录?下面介绍4种方法列出当前路径下的目录,大家参考使用吧
    2014-01-01
  • linux定时任务基础命令介绍(14)

    linux定时任务基础命令介绍(14)

    这篇文章主要为大家详细介绍了linux定时任务基础命令,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • 使用ntpdate工具校正linux服务器时间(实现方法)

    使用ntpdate工具校正linux服务器时间(实现方法)

    下面小编就为大家带来一篇使用ntpdate工具校正linux服务器时间(实现方法)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • shell脚本ssh远程执行命令给变量赋值的问题解决

    shell脚本ssh远程执行命令给变量赋值的问题解决

    本文主要介绍了shell脚本ssh远程执行命令给变量赋值的问题解决,就是从A机器通过SSH方式到B机器,并执行相关的命令,具有一定的参考价值,感兴趣的可以了解一下
    2023-07-07

最新评论