如题所示,在安装了oracle的Linux服务器上执行脚本时出现如题的错误:
1
2
|
[oracle@hp-db
test
]$ .
/getSysdate
.sh
.
/getSysdate
.sh: line 10: sqlplus:
command
not found
|
问题分析:
情况一:使用root用户切换到oracle用户时使用了以下命令
1
|
[root@hp-db
test
]
# su oracle
|
这样切换用户导致从root用户切换到oracle用户时没有加载/home/oracle/.bash_profile文件,因此环境变量没有加载进来
正确命令应该是:
1
|
[root@hp-db
test
]
# su - oracle
|
然后进行测试:
1
2
|
[oracle@hp-db ~]$
echo
$ORACLE_HOME
/home/oracle/app/oracle/product/11
.2.0
/dbhome_1
|
1
|
[oracle@hp-db ~]$ sqlplus
"/ as sysdba"
|
可以发现已经可以正常进入SQL命令模式了
情况二:/home/oracle/.bash_profile文件中的oracle环境变量设置得不太正确
如果是这个文件中的环境变量设置不对的话,只需要参考一个正确的配置文件根据实际情况修改即可,参考文件如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
#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是这样的:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
#!/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
|
再次执行效果如下:
1
2
3
|
[oracle@hp-db
test
]$ .
/getSysdate
.sh
2016-08-19
The rows is 2016-08-19
|
本文转自 pangfc 51CTO博客,原文链接:http://blog.51cto.com/983836259/1861364,如需转载请自行联系原作者