sqlplus与shell互相传值的几种情况

情况一:在shell中最简单的调用sqlplus

$cat test.sh
#!/bin/sh
sqlplus oracle/oracle@oracle>file.log <
EMPNO   EMPNAME          SAL      DEPTNO
-----   -------------    -----    ------
10002   Frank Naude      500      20
10001   Scott Tiger      1000     40
--省略若干系统提示信息-------

将执行过程重定向入文件file.log,可通过cat file.log查看

 

情况二:直接将sqlplus的值赋值给shell变量

$cat test.sh
#!/bin/sh
# 将sqlplus的结果输出给变量VALUE
# set命令的使用可查询手册
#注意shell中等号两边不能有空格
VALUE=`sqlplus -S /nolog <

显示结果正确,表test共2条记录

 

情况三:间接将sqlplus的值赋值给shell变量

$cat test.sh
#!/bin/sh
#利用COL column NEW_VALUE variable定义变量
#sqlplus执行完后最后返回值为v_coun
#利用$?将最后返回值赋值给VALUE,也即为test的记录数
sqlplus -S /nolog <

脚本执行结果中第一个2为sqlplus返回值,第二个2为VALUE的值

 

情况四:将shell变量的值传给sqlplus使用

$cat test.sh
#!/bin/sh
#sqlplus引用shell变量TABLENAME的值
#注意赋值时,等号两边不能有空格
TABLENAME="test"
sqlplus -S oracle/oracle@oracle <

脚本执行结果为:select * from test;的结果

 

情况五:通过交互方式手工输入shell变量值

$cat test.sh
#!/bin/sh
#将手工输入变量值读入变量TABLENAME
echo  "Enter the tablename you want to select:"
read TABLENAME
sqlplus -S oracle/oracle@oracle <

脚本执行结果为select * from test的执行结果

 

情况六:通过重定向文件方式,并生成日志

source ~/.bash_profile
sqlplus test/test@orcl < /home/test/test.sql >>/home/log/test.log
echo "end-------------------"

 

你可能感兴趣的:(数据库)