Linux/Unix shell sql 之间传递变量
2014-08-08 13:55
411 查看
灵活结合Linux/Unix Shell 与SQL 之间的变量传输,极大程度的提高了DBA的工作效率,本文针对Linux/Unix shell sql 之间传递变量给出几个简单的示例以供参考。
Linux/Unix 下调用SQL,RAMN 请参考:Linux/Unix shell 脚本中调用SQL,RMAN脚本
一、示例
[python] view
plaincopyprint?
1、shell变量接受sql返回值之方式一
oracle@SZDB:~> more ./retval.sh
#!/bin/bash
RETVAL=`sqlplus -silent scott/tiger <<EOF
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
# Author : Robinson Cheng
# Blog : http://blog.csdn.net/robinson_0612
sqlplus -S "scott/tiger" <<EOF
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" <<EOF
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
SCOTT
二、更多参考
Linux/Unix 下调用SQL,RAMN 请参考:Linux/Unix shell 脚本中调用SQL,RMAN脚本
一、示例
[python] view
plaincopyprint?
1、shell变量接受sql返回值之方式一
oracle@SZDB:~> more ./retval.sh
#!/bin/bash
RETVAL=`sqlplus -silent scott/tiger <<EOF
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
# Author : Robinson Cheng
# Blog : http://blog.csdn.net/robinson_0612
sqlplus -S "scott/tiger" <<EOF
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" <<EOF
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
SCOTT
二、更多参考
相关文章推荐
- Linux/Unix shell sql 之间传递变量
- Linux/Unix shell sql 之间传递变量
- Linux/Unix shell 参数传递到SQL脚本
- 窗口之间变量参数传递的实现方法
- 在SQL语句中如何将字符串变量传递给In语句
- 在SQL语句中如何将字符串变量传递给In语句
- awk与shell之间的变量互相传递方法
- c# ArcEngine二次开发之“窗体之间传递AxMapcontrol 变量”
- pl/sql中在where in()子句里怎么使用字符串变量来传递查询条件?
- 一些比较少用的SQL语句,实现不同数据库之间信息的传递
- [原创]BCB的FORM1与FORM2之间的变量传递及应用,学会后分享给大家.
- OpenGL与GLSL之间变量的传递
- 毕业论文设计客户订单界面及代码(WinForm之间传递参数,公式的Sql计算方式)
- 在两个ASP.NET页面之间传递变量【转】
- 第2章 Java编程基础——FAQ2.14 变量之间传值时可分为值传递和引用传递, 那么它们有何区别?
- 在OpenGL和GLSL之间传递变量
- vbscript与javascript之间如何传递变量(包括服务器端与客户端)
- 在SQL语句中如何将字符串变量传递给In语句
- 我理解c#(一): 参数传递和变量复制之间的关系
- 在OpenGL和GLSL之间传递变量