您现在的位置是:首页 > 文章详情

解决执行脚本时爆“sqlplus: command not found”的问题

日期:2016-10-13点击:486

如题所示,在安装了oracle的Linux服务器上执行脚本时出现如题的错误:

[oracle@hp-db test]$ ./getSysdate.sh ./getSysdate.sh: line 10: sqlplus: command not found

问题分析:

情况一:使用root用户切换到oracle用户时使用了以下命令

[root@hp-db test]# su oracle

这样切换用户导致从root用户切换到oracle用户时没有加载/home/oracle/.bash_profile文件,因此环境变量没有加载进来

正确命令应该是:

[root@hp-db test]# su - oracle

然后进行测试:

[oracle@hp-db ~]$ echo $ORACLE_HOME /home/oracle/app/oracle/product/11.2.0/dbhome_1
[oracle@hp-db ~]$ sqlplus "/ as sysdba"

可以发现已经可以正常进入SQL命令模式了

情况二:/home/oracle/.bash_profile文件中的oracle环境变量设置得不太正确

如果是这个文件中的环境变量设置不对的话,只需要参考一个正确的配置文件根据实际情况修改即可,参考文件如下:

#Oracle Config export TMP=/tmp export TMPDIR=$TMP export ORACLE_HOSTNAME=hp-db export ORACLE_BASE=/home/oracle/app export ORACLE_HOME=$ORACLE_BASE/oracle/product/11.2.0/dbhome_1 export ORACLE_SID=yoursid export ORACLE_TERM=xterm export ORACLE_UNQNAME=yourunqname export PATH=/usr/sbin:$ORACLE_HOME/bin:$PATH export NLS_LANG="AMERICAN_AMERICA.AL32UTF8" export EMLOCALHOST=localhost.oracle export NLS_DATE_FORMAT="YYYY-MM-DD  HH24:MI:SS" export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib export CLASSPATH=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib

附:最上面的那个shell脚本getSysdate.sh是这样的:

#!/bin/bash VALUE=`sqlplus -S "/ as sysdba" << ! set heading off set feedback off set pagesize 0 set verify off set echo off select to_char(sysdate,'yyyy-mm-dd') today from dual; exit !` echo $VALUE if [ -n "$VALUE" ]; then echo "The rows is $VALUE" exit 0 else echo "There is no row" fi

再次执行效果如下:

[oracle@hp-db test]$ ./getSysdate.sh 2016-08-19 The rows is 2016-08-19


原文链接:https://blog.51cto.com/983836259/1861364
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章