Welcome 微信登录

首页 / 数据库 / MySQL / Sh脚本中查询Oracle v$视图时需要在$号前加转义符“”

DBA经常会部署一些sh脚本登陆Oracle数据库查询v$动态视图得到一些东西来实际管理自动化的目的,但在sh脚本中写ORACLE SQL语句时,如果语句查询v$视图,直接写v$XXXX是不能成功的,shell会将$当成一个参数来处理。以下面一段简单的sh脚本为例:/home/oracle/s_parameter.sh
sqlplus /nolog<<EOFconn / as sysdbacol inst_id for 99col name for a48col value for a64set pagesize 1000 line 180spool /home/oracle/1111.txtselect inst_id,name,value from gv$system_parameter order by 1,2;spool offquitEOF
 当执行 sh /home/oracle/s_parameter.sh时,会报如下表或视图不存在的错误错:
SQL*Plus: Release 11.2.0.3.0 Production on Sun Aug 18 11:28:17 2013 Copyright (c) 1982, 2011, Oracle. All rights reserved. SQL> Connected.SQL> SQL> SQL> SQL> SQL> SQL> select inst_id,name,value from gv order by 1,2*ERROR at line 1:ORA-00942: table or view does not exist SQL> SQL> Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production With the Partitioning, OLAP, Data Mining and Real Application Testing options
 本来sh脚本文件中写的是gv$system_parameter的,但是执行时,只能识别到gv,$以后面的视图名都未被识别。处理这个问题其实很简单,只需要在$前加上一个“”转义符即可,例如
sqlplus /nolog<<EOFconn / as sysdbacol inst_id for 99col name for a48col value for a64set pagesize 1000 line 180spool /home/oracle/1111.txtselect inst_id,name,value from gv$system_parameter order by 1,2;spool offquitEOF
再执行/home/oracle/s_parameter.sh就可以得到正确的结果(注意上面表格中红色的“”号) 更多Oracle相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12Oracle数据库查看使用默认密码的用户信息Linux/Unix平台如何查看OS上存在有哪些数据库或实例相关资讯      Oracle转义符  本文评论 查看全部评论 (0)
表情: 姓名: 字数

<