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

你可能感兴趣的:(oracle)