oracle视图执行脚本,Sh脚本中查询Oracle v$视图时需要在$号前加转义符“\”
DBA經(jīng)常會(huì)部署一些sh腳本登陸Oracle數(shù)據(jù)庫(kù)查詢v$動(dòng)態(tài)視圖得到一些東西來實(shí)際管理自動(dòng)化的目的,但在sh腳本中寫ORACLE SQL語句時(shí),如果語句查詢v$視圖,直接寫v$XXXX是不能成功的,shell會(huì)將$當(dāng)成一個(gè)參數(shù)來處理。
以下面一段簡(jiǎn)單的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
當(dāng)執(zhí)行 sh /home/oracle/s_parameter.sh時(shí),會(huì)報(bào)如下表或視圖不存在的錯(cuò)誤錯(cuò):
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的,但是執(zhí)行時(shí),只能識(shí)別到gv,$以后面的視圖名都未被識(shí)別。
處理這個(gè)問題其實(shí)很簡(jiǎn)單,只需要在$前加上一個(gè)“\”轉(zhuǎn)義符即可,例如
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
再執(zhí)行/home/oracle/s_parameter.sh就可以得到正確的結(jié)果(注意上面表格中紅色的“\”號(hào))
總結(jié)
以上是生活随笔為你收集整理的oracle视图执行脚本,Sh脚本中查询Oracle v$视图时需要在$号前加转义符“\”的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 2d开源游戏引擎_前5名:构建出色的CL
- 下一篇: Cisco路由器密码恢复