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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值