shell调用oracle存储过程案例

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

    原文作者:马克力
    原文地址: https://blog.csdn.net/mark4541437/article/details/103044270
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞