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

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

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

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

#! /bin/shlogpath="log"filepath="/home/ap/user"#输入Oracle数据库的用户名密码等信息DBINFO="username/password@ip:port/orcl"if [ ! -d ${logpath} ]then mkdir logfiecho "[`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>&1whenever oserror exit 1;whenever sqlerror exit 1;@${filepath}/initTable.sql@${filepath}/initTable2.sqlquit!if [ $? -ne 0 ]then echo "[`date +'%Y%m%d %H:%M:%S'`] Error: Initialize initTable failed!" >> ${logpath} exit 1fiecho "[`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; 这句话删除掉,程序就能往下执行了,当然需要根据自身需要选择添加。希望这篇文章对大家有所帮助。————————————————

#! /bin/shlogpath="log"filepath="/home/oracle/sss"#输入Oracle数据库的用户名密码等信息DBINFO="database/pass"if [ ! -d ${logpath} ]then mkdir logfiecho "[`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>&1whenever oserror exit 1;whenever sqlerror exit 1;@${filepath}/s1.sqlcommit;@${filepath}/s2.sqlcommit;quit!if [ $? -ne 0 ]then echo "[`date +'%Y%m%d %H:%M:%S'`] Error: Initialize initTable failed!" exit 1fi echo "[`date +'%Y%m%d %H:%M:%S'`] Initialize initTable successed."

版权声明:本文为CSDN博主「three_j」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。原文链接:https://blog.csdn.net/three_j/article/details/84927958

相关推荐

港的笔顺 笔画数:12 拼音:gǎng 部首:氵 笔画数:12 拼音:gǎng 部首:氵
2025LPL第一赛段常规赛售票信息公布
365体育app

2025LPL第一赛段常规赛售票信息公布

📅 09-03 👁️ 1927
cf手游改名字方法介绍
365bet网址搜索器

cf手游改名字方法介绍

📅 10-18 👁️ 5087
标签:德誉金融怎么样
365bet在线体育投注网

标签:德誉金融怎么样

📅 09-14 👁️ 9406
雷霆世纪台式电脑排行榜
365bet网址搜索器

雷霆世纪台式电脑排行榜

📅 07-11 👁️ 4494
1.卡塔尔世界杯球员入场音乐 Arhbo
365体育app

1.卡塔尔世界杯球员入场音乐 Arhbo

📅 07-30 👁️ 1262