最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

Sh脚本中查询Oraclev$视图时需要在$号前加转义符“”

来源:懂视网 责编:小采 时间:2020-11-09 10:42:21
文档

Sh脚本中查询Oraclev$视图时需要在$号前加转义符“”

Sh脚本中查询Oraclev$视图时需要在$号前加转义符:DBA经常会部署一些sh脚本登陆ORACLE数据库查询v$动态视图得到一些东西来实际管理自动化的目的,但在sh脚本中写ORACLE SQL语句时, DBA经常会部署一些sh脚本登陆Oracle数据库查询v$动态视图得到一些东西来实际管理自动化的目的,但在sh脚本中写ORACL
推荐度:
导读Sh脚本中查询Oraclev$视图时需要在$号前加转义符:DBA经常会部署一些sh脚本登陆ORACLE数据库查询v$动态视图得到一些东西来实际管理自动化的目的,但在sh脚本中写ORACLE SQL语句时, DBA经常会部署一些sh脚本登陆Oracle数据库查询v$动态视图得到一些东西来实际管理自动化的目的,但在sh脚本中写ORACL

DBA经常会部署一些sh脚本登陆ORACLE数据库查询v$动态视图得到一些东西来实际管理自动化的目的,但在sh脚本中写ORACLE SQL语句时,

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 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<

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就可以得到正确的结果(注意上面表格中红色的“\”号)

linux

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

Sh脚本中查询Oraclev$视图时需要在$号前加转义符“”

Sh脚本中查询Oraclev$视图时需要在$号前加转义符:DBA经常会部署一些sh脚本登陆ORACLE数据库查询v$动态视图得到一些东西来实际管理自动化的目的,但在sh脚本中写ORACLE SQL语句时, DBA经常会部署一些sh脚本登陆Oracle数据库查询v$动态视图得到一些东西来实际管理自动化的目的,但在sh脚本中写ORACL
推荐度:
标签: 查询 文件 的时候
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top