linux变量和数据库变量,Linux/Unix shell sql 之间传递变量

灵活结合Linux/Unix Shell 与SQL 之间的变量传输,极大程度的提高了DBA的工作效率,本文针对Linux/Unix shell sql 之间传递变量给出几个简单的示例以供参考。

Linux/Unix 下调用SQL,RAMN 请参考:Linux/Unix shell 脚本中调用SQL,RMAN脚本 http://www.linuxidc.com/Linux/2012-09/70310.htm

一、示例

1、shell变量接受sql返回值之方式一

Oracle@SZDB:~> more ./retval.sh

#!/bin/bash

RETVAL=`sqlplus -silent scott/tiger <

SET PAGESIZE 0 FEEDBACK OFF VERIFY OFF HEADING OFF ECHO OFF

SELECT * FROM emp WHERE ename='SCOTT';

EXIT;

EOF`

if [ -z "$RETVAL" ]; then

echo "No rows returned from database"

exit 0

else

echo $RETVAL

fi

oracle@SZDB:~> chmod u+x retval.sh

oracle@SZDB:~> ./retval.sh

7788 SCOTT ANALYST 7566 19-APR-87 34171.88 20

2、shell变量接受sql返回值之方式二

oracle@SZDB:~> more ./retval_2.sh

#!/bin/bash

sqlplus -S "scott/tiger" <

SET PAGESIZE 0 FEEDBACK OFF VERIFY OFF HEADING OFF ECHO OFF

col cnt new_value v_cnt

SELECT count(*) cnt FROM emp WHERE deptno=10;

exit v_cnt

EOF

VALUE="$?"

echo "show rows for deptno 10:$VALUE"

3、将shell变量作为参数传递给sql脚本

oracle@SZDB:~> more ./retval_3.sh

#!/bin/bash

v_empno="$1"

sqlplus -S "scott/tiger" <

SET PAGESIZE 0 FEEDBACK OFF VERIFY OFF HEADING OFF ECHO OFF

SELECT ename FROM emp WHERE empno=$v_empno;

exit

EOF

exit

oracle@SZDB:~> ./retval_3.sh 7788

SCOTT0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值