oracle视图执行脚本,Sh脚本中查询Oracle v$视图时需要在$号前加转义符“\”

DBA经常会部署一些sh脚本登陆Oracle数据库查询v$动态视图得到一些东西来实际管理自动化的目的,但在sh脚本中写ORACLE SQL语句时,如果语句查询v$视图,直接写v$XXXX是不能成功的,shell会将$当成一个参数来处理。

以下面一段简单的sh脚本为例:/home/oracle/s_parameter.sh

sqlplus /nolog<

conn / as sysdba

col inst_id for 99

col name for a48

col value for a64

set pagesize 1000 line 180

spool /home/oracle/1111.txt

select inst_id,name,value from gv$system_parameter order by 1,2;

spool off

quit

EOF

当执行 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 fromgvorder 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<

conn / as sysdba

col inst_id for 99

col name for a48

col value for a64

set pagesize 1000 line 180

spool /home/oracle/1111.txt

select inst_id,name,value from gv\$system_parameter order by 1,2;

spool off

quit

EOF

再执行/home/oracle/s_parameter.sh就可以得到正确的结果(注意上面表格中红色的“\”号)

0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值