筛网怎么做网站,自己怎么做农好产品网站,淘客网站免费开源源码,内蒙古城乡和住房建设厅网站DBA经常会部署一些sh脚本登陆Oracle数据库查询v$动态视图得到一些东西来实际管理自动化的目的#xff0c;但在sh脚本中写ORACLE SQL语句时#xff0c;如果语句查询v$视图#xff0c;直接写v$XXXX是不能成功的#xff0c;shell会将$当成一个参数来处理。以下面一段简单的sh脚…DBA经常会部署一些sh脚本登陆Oracle数据库查询v$动态视图得到一些东西来实际管理自动化的目的但在sh脚本中写ORACLE SQL语句时如果语句查询v$视图直接写v$XXXX是不能成功的shell会将$当成一个参数来处理。以下面一段简单的sh脚本为例/home/oracle/s_parameter.shsqlplus /nologconn / 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 2013Copyright (c) 1982, 2011, Oracle. All rights reserved.SQL Connected.SQL SQL SQL SQL SQL SQLselect inst_id,name,value fromgvorder by 1,2*ERROR at line 1:ORA-00942: table or view does not existSQL 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 /nologconn / 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就可以得到正确的结果(注意上面表格中红色的“\”号)