记录一下"将sqlplus的值传递给os shell的方法"

声明:本次记录,大部内容来源网络收集,但经过本人实践验证。

1. 直接将sqlplus的值赋值给shell变量

$cat test.sh
#!/bin/sh
# 将sqlplus的结果输出给变量VALUE
# set命令的使用可查询手册
#注意shell中等号两边不能有空格
VALUE=`sqlplus -S /nolog <<EOF
set heading off feedback off pagesize 0 verify off echo off
conn oracle/oracle@oracle
select count(*) from test;
exit
EOF`
#输出记录数
echo "The number of rows is $VALUE."
$sh test.sh
The number of rows is    2.
显示结果正确,表test共2条记录

2. 与1类似,但是另一种表现形式
cat >> test.sql << eof
set heading off
set feedback off
select count(*) from dba_tables;
exit
eof
value=$(sqlplus -s / as sysdba @test.sql)
echo $value
返回:正确的记录数

 
3. 间接将sqlplus的值赋值给shell变量
$cat test.sh
#!/bin/sh
#利用COL column NEW_VALUE variable定义变量
#sqlplus执行完后最后返回值为v_coun
#利用$?将最后返回值赋值给VALUE,也即为test的记录数
sqlplus -s / as sysdba <<EOF
set heading off feedback off pagesize 0 verify off echo off
conn oracle/oracle@oracle
col coun new_value v_coun
select count(*) coun from dba_tables
where rownum<=100;
exit v_coun
EOF
VALUE="$?"
echo "The number of rows is $VALUE."
备注:不建议使用方法3,在linux及unix 系统中只能返回0-255之间的数值,一旦超过就会溢出,显示一些奇怪的数字。 所以建议使用方法1或2。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值