分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow
也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!
灵活结合Linux/Unix Shell 与SQL 之间的变量传输,极大程度的提高了DBA的工作效率,本文针对Linux/Unix shell sql 之间传递变量给出几个简单的示例以供参考。
Linux/Unix 下调用SQL,RAMN 请参考:Linux/Unix shell 脚本中调用SQL,RMAN脚本
一、示例
1、shell变量接受sql返回值之方式一oracle@SZDB:~> more ./retval.sh#!/bin/bashRETVAL=`sqlplus -silent scott/tiger <<EOFSET PAGESIZE 0 FEEDBACK OFF VERIFY OFF HEADING OFF ECHO OFFSELECT * FROM emp WHERE ename='SCOTT';EXIT;EOF`if [ -z "$RETVAL" ]; then echo "No rows returned from database" exit 0else echo $RETVALfioracle@SZDB:~> chmod u+x retval.shoracle@SZDB:~> ./retval.sh7788 SCOTT ANALYST 7566 19-APR-87 34171.88 202、shell变量接受sql返回值之方式二oracle@SZDB:~> more ./retval_2.sh#!/bin/bash# Author : Robinson Cheng # Blog : http://blog.csdn.net/robinson_0612sqlplus -S "scott/tiger" <<EOFSET PAGESIZE 0 FEEDBACK OFF VERIFY OFF HEADING OFF ECHO OFFcol cnt new_value v_cntSELECT count(*) cnt FROM emp WHERE deptno=10;exit v_cntEOFVALUE="$?"echo "show rows for deptno 10:$VALUE"3、将shell变量作为参数传递给sql脚本oracle@SZDB:~> more ./retval_3.sh#!/bin/bashv_empno="$1"sqlplus -S "scott/tiger" <<EOFSET PAGESIZE 0 FEEDBACK OFF VERIFY OFF HEADING OFF ECHO OFFSELECT ename FROM emp WHERE empno=$v_empno;exitEOFexitoracle@SZDB:~> ./retval_3.sh 7788SCOTT
二、更多参考
有关基于用户管理的备份和备份恢复的概念请参考
Oracle 基于用户管理恢复的处理(详细描述了介质恢复及其处理)
Oracle 基于备份控制文件的恢复(unsing backup controlfile)
有关RMAN的备份恢复与管理请参考
RMAN 备份路径困惑(使用plus archivelog时)
有关ORACLE体系结构请参考