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

发布时间:2020-07-21 01:26:36 作者:pangfc
来源:网络 阅读:3511

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


推荐阅读:
  1. SQL结构化查询语——之DML语言
  2. 高效的SQL(函数索引优化VIEW一例)

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

sql 脚本 shell

上一篇:记一次MySQL主从复制出错

下一篇:玩大数据的你竟然不知道容器?——Docker入门之安装Docker及MySQL

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》