shell调用oracle存储过程案例
#!/usr/bin/ksh
否则将参数赋给指定变量
if [ $# -lt 5 ];then
echo “[date
][ERRO][数据装载脚本传入了错误的参数$*]”
echo ” 正确调用格式: exec_proc.ksh [存储过程名称] [数据库名称] [数据库用户] [数据库密码] [会计日期]”
exit 1
else
参数处理
#参数1 存储过程名称: PROC
PROC=${1}
#参数2 :数据库名称:DBNAME
DBNAME=${2}
#参数3 数据库用户:DBUSER
DBUSER=${3}
#参数4 数据库密码:DBPASS
DBPASS=${4}
#参数5 会计日期: taskDate
taskDate=${5}
fi
#连接数据源测试
sqlstring=sqlplus -silent ${DBUSER}/${DBPASS}@${DBNAME} << ! set pagesize 0 feedback off verify off heading off echo off select to_char(sysdate) from dual ; quit !
#分析测试结构
echo $sqlstring | grep “ERROR:” | awk ‘{print $1}’ | read dbconnstaut
判断连接是否成功
if [ “X${dbconnstaut}” != “X” ]; then
echo “[date
][ERRO][连接数据源时错误[$DBNAME]!]”
echo “返回结果:[ $?]”
exit 1
fi
#连接数据源测试
sqlstring=sqlplus -silent ${DBUSER}/${DBPASS}@${DBNAME} << EOF set pagesize 0 feedback off verify off heading off echo off set serveroutput on declare taskDate varchar2(8); outcode number; message varchar2(2000); begin ${PROC}('${taskDate}',outcode,message); dbms_output.put_line(outcode|| ', '||message); end; / quit EOF
#判断存储过程返回值
out=echo $sqlstring |awk -F '[,]' '{print $1}'
if [[ out -eq 0 ]]
then
echo $sqlstring |awk -F ‘[,]’ ‘{print “返回信息:”$0}’
exit 0
else
echo $sqlstring |awk -F ‘[,]’ ‘{print “返回信息:”$0}’
exit 1
fi