http://blog.itpub.net/13885898/viewspace-1670297/

有时候我们可能会需要在Shell脚本中执行SELECT语句,并将结果赋值给一个变量,对于这样的情形,我们可以用以下的方法来达到目的。

点击(此处)折叠或打开

  1. #!/bin/ksh
  2. #
  3. # Created : 2015.05.25
  4. # Updated : 2015.05.25
  5. # Author : Jet Chenxi Zhang
  6. # Description : Get SELECT result in Shell
  7. # Variable Definitions #
  8. ORACLE_SID=audtest
  9. ORACLE_HOME=/app/oracle/product/database/11.2.0/db_1
  10. PATH=$PATH:$ORACLE_HOME/bin
  11. DBNAME=
  12. # Get Database name by quering v$database #
  13. DBNMAE=`
  14. sqlplus -s /nolog <<EOF
  15. set echo off feedback off heading off underline off;
  16. conn / as sysdba;
  17. select name from v\\$database;
  18. exit;
  19. EOF`
  20. echo "Database name: "$DBNMAE

如上代码,可以将获取Database Name,执行结果如下:

  1. [oracle@hxddcx02 ~]$ ./query_dbname.sh
  2. Database name: AUDTEST

可以看到SELECT的结果已被正确赋值给Shell的变量。如果SELECT中有多个列的值,也可以用此方法,只是需要将结果进行分拆,如用awk:

点击(此处)折叠或打开

  1. #!/bin/ksh
  2. #
  3. # Created : 2015.05.25
  4. # Updated : 2015.05.25
  5. # Author : Jet Chenxi Zhang
  6. # Description : Get SELECT results in Shell
  7. # Variable Definitions #
  8. ORACLE_SID=audtest
  9. ORACLE_HOME=/app/oracle/product/database/11.2.0/db_1
  10. PATH=$PATH:$ORACLE_HOME/bin
  11. QUERYRES=
  12. DBID=
  13. DBNAME=
  14. # Get Database name by quering v$database #
  15. QUERYRES=`
  16. sqlplus -s /nolog <<EOF
  17. set echo off feedback off heading off underline off;
  18. conn / as sysdba;
  19. select dbid, name from v\\$database;
  20. exit;
  21. EOF`
  22. DBID=`echo $QUERYRES | awk -F' ' '{print $1}'`
  23. DBNAME=`echo $QUERYRES | awk -F' ' '{print $2}'`
  24. echo "Database ID: "$DBID
  25. echo "Database name: "$DBNAME

运行结果如下:

  1. [oracle@hxddcx02 ~]$ ./query_dbname2.sh
  2. Database ID: 811711272
  3. Database name: AUDTEST

[转]Shell脚本中获取SELECT结果值的方法的更多相关文章

  1. Shell脚本中获取select值

    最近做一个数据清理,根据行号清理,所以需要查出这个行的最大最小值出来进行删除,如果靠手动每次去查,太麻烦所以就用在sh脚本当中执行SELECT语句,并将结果赋值给一个变量. sh脚本如下 #! /bi ...

  2. Linux Shell脚本中获取本机ip地址方法

    ifconfig -a|grep inet|grep -v 127.0.0.1|grep -v inet6|awk '{print $2}'|tr -d "addr:"​ 命令解释 ...

  3. shell脚本中获取当前所在目录地址

    shell脚本中获取当前所在目录如下 #!/bin/bash work_path=$() cd ${work_path} work_path=$(pwd) cd ${work_path}/src

  4. Shell脚本中判断输入参数个数的方法投稿:junjie 字体:[增加 减小] 类型:转载

    Shell脚本中判断输入参数个数的方法 投稿:junjie 字体:[增加 减小] 类型:转载   这篇文章主要介绍了Shell脚本中判断输入参数个数的方法,使用内置变量$#即可实现判断输入了多少个参数 ...

  5. linux,shell脚本中获取脚本的名字,使用脚本的名字。

    需求描述: 写shell脚本的过程中,有时会需要获取脚本的名字,比如,有的时候,脚本 中会有usage()这种函数,可能就会用到脚本的名字. 实现方法: shell脚本中,通过使用$0就可以获取到脚本 ...

  6. 如何在shell脚本中获取当前用户名?

    答:使用环境变量USER即可 如在脚本中打印当前用户名; #!/bin/sh echo "user name = ${USER}"

  7. JAVA中获取文件MD5值的方法

    1 DigestUtils.md5Hex(new FileInputStream(path)); 如果你只需要使用标准的MD5,其实一行代码就够了,JAVA自带的commons-codec包就提供了获 ...

  8. shell脚本中case select 的使用

    #!/bin/bash # case echo "1.Install PHP" echo "2.Install Mysql" echo "3.Inst ...

  9. shell脚本中获取本机ip地址的方法

    ipaddr='172.0.0.1' ipaddr=$(ip addr | awk '/^[0-9]+: / {}; /inet.*global/ {print gensub(/(.*)\/(.*)/ ...

随机推荐

  1. git gui :Updating the Git index failed. A rescan will be automatically started to res

    这个是由于unix系统的换行符和windows的换行符不一致造成的结果.你在安装git的时候,设置了成使用LF,即unix换行符,可是你是在windows下进行文件编辑的,所以会出现上面的警告.其实这 ...

  2. Linux环境下GNU, GCC, G++编译器(转)

    一,GNU GNU是“GNU 's Not Unix”的递归缩写, Stallman宣布GNU应当发音为Guh-NOO(革奴)以避免与new这个单词混淆(注:Gnu在英文中原意为非洲牛羚,发音与new ...

  3. Mybatis3.x与Spring4.x整合

    一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: mvn archetype:create -DgroupId=me.gacl -DartifactId=spring4-myba ...

  4. 【apache2】apache2查看错误日志、请求日志

    1.一般存储路径在 [ /var/log/apache2/ ]下面, 2.错误日志和请求日志 必须要进行定期清理. 清理完成后,必须重启apache  [  cd /  ;  service apac ...

  5. msado.tli

    // Created by Microsoft (R) C/C++ Compiler Version 10.00.40219.01 (d0b01b1b).//// e:\threadpool\mysq ...

  6. Tomcat服务器配置https协议(Tomcat HTTPS/SSL 配置)

    通常商用服务器使用https协议需要申请SSL证书,证书都是收费的,价格有贵的有便宜的.它们的区别是发行证书的机构不同,贵的证书机构更权威,证书被浏览器否决的几率更小. 非商业版本可以通过keytoo ...

  7. BEGINNING SHAREPOINT&#174; 2013 DEVELOPMENT 第10章节--SP2013中OAuth概览 应用程序验证

    BEGINNING SHAREPOINT® 2013 DEVELOPMENT 第10章节--SP2013中OAuth概览  应用程序验证 既然你懂得了什么是应用程序身份.而且知道怎样在SP中创建和设置 ...

  8. javascript sort方法容易犯错的地方

    sort方法用来对数组排序非常方便.但是sort(func)这个func参数的构造却很容易混淆. sort判断func的返回值是判断正负,而不是ture和false.所以务必保证返回值要么负数要么正数 ...

  9. CTC loss 理解

    参考文献 CTC学习笔记(一) 简介:https://blog.csdn.net/xmdxcsj/article/details/51763868 CTC学习笔记(二) 训练和公式推导 很详细的公示推 ...

  10. Django Drops

    1.Django Intro 2.Django Install (1) PIP安装 sudo apt-get isntall python-pip sudo pip install Django (2 ...