首页 > 网络 > 其他 >

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

2016-10-17

解决执行脚本时爆“sqlplus: command not found”的问题:情况一:使用root用户切换到oracle用户时使用了以下命令[root@hp-dbtest] suoracle,这样切换用户导致从root用户切换到oracle用户时没有加载 home oracle bash_profile文件,因此环境变量没有加载进来。

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

[oracle@hp-dbtest]$./getSysdate.sh
./getSysdate.sh:line10:sqlplus:commandnotfound

问题分析:

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

[root@hp-dbtest]#suoracle

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

正确命令应该是:

[root@hp-dbtest]#su-oracle

然后进行测试:

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

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

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

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

#OracleConfig
exportTMP=/tmp
exportTMPDIR=$TMP
exportORACLE_HOSTNAME=hp-db
exportORACLE_BASE=/home/oracle/app
exportORACLE_HOME=$ORACLE_BASE/oracle/product/11.2.0/dbhome_1
exportORACLE_SID=yoursid
exportORACLE_TERM=xterm
exportORACLE_UNQNAME=yourunqname
exportPATH=/usr/sbin:$ORACLE_HOME/bin:$PATH
exportNLS_LANG="AMERICAN_AMERICA.AL32UTF8"
exportEMLOCALHOST=localhost.oracle
exportNLS_DATE_FORMAT="YYYY-MM-DDHH24:MI:SS"
exportLD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib
exportCLASSPATH=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib

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

#!/bin/bash
VALUE=`sqlplus-S"/assysdba"<

再次执行效果如下:

[oracle@hp-dbtest]$./getSysdate.sh
2016-08-19
Therowsis2016-08-19
相关文章
最新文章
热点推荐