oracle执行plus时跳出,解决执行脚本时爆“sqlplus: command not found”的问题

如题所示,在安装了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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值