Shell脚本批量执行Oracle数据库的SQL脚本

最近在做项目时需要执行很多SQL文件,为了方便所以编写了一个shell脚本,并且把所有的错误信息都记录在一个日志文件中。

下面是详细的脚本,简单又适用。

#! /bin/sh
logpath="log"
filepath="/home/ap/user"
#输入Oracle数据库的用户名密码等信息
DBINFO="username/password@ip:port/orcl"
if [ ! -d ${logpath} ]
then
 mkdir log
fi
echo "[`date +'%Y%m%d %H:%M:%S'`] Info: Begin to execute init sql!"
logfile="${logpath}/init_table_data_info.log"
#“${logfile} 2>&1”这里的意思就是把标准输出信息和错误输出信息都记录在init_table_data_info.log文件中
sqlplus -s ${DBINFO} << ! > ${logfile} 2>&1
whenever oserror exit 1;
whenever sqlerror exit 1;
@${filepath}/initTable.sql
@${filepath}/initTable2.sql
quit
!
if [ $? -ne 0 ]
then
    echo "[`date +'%Y%m%d %H:%M:%S'`] Error: Initialize initTable failed!"  >> ${logpath}
    exit 1
fi
echo "[`date +'%Y%m%d %H:%M:%S'`] Initialize initTable  successed."  >> ${logpath}

上面就是执行脚本的全部内容,但有一点需要特别注意,这个脚本中有一句这样的描述:whenever sqlerror exit 1;

这就表示sql脚本在执行的过程中如果有一个错误就会退出当前脚本。在实际工作中,我们其实不希望因为一个正常的SQL错误就退出脚本,比如脚本中有这样一段:

DROP TABLE TBNAME;
CREATE TABLE TBNAME(...);

如果表TBNAME不存在,则DROP 就会报错,而实际上这是正常的错误,我们还是希望脚本正常的往下执行,所以我们需要把

whenever sqlerror exit 1; 这句话删除掉,程序就能往下执行了,当然需要根据自身需要选择添加。希望这篇文章对大家有所帮助。

 

 

  • 7
    点赞
  • 60
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值