我想在cron中运行一个包含一些sqlplus命令的脚本。
问题是,在cron中执行sqlplus命令时,由于某种原因不会执行。如果我自己执行它,脚本运行得很好。
我查看了一些论坛,甚至stackoverflow.com上的主题,找到了一些关于正确设置环境变量的提示。但是,即使在仔细检查之后,脚本也不起作用。
下面是我的脚本:
echo $ORACLE_HOME|grep "oracle" > /dev/null
if [ $? = 1 ] ; then
echo "Setting environment variable"
# Setting oracle environmet
. /usr/oracle/product/10.2.0/.profile
NLS_LANG='AMERICAN_GERMANY.WE8ISO8859P1'
fi
/usr/oracle/product/10.2.0/bin/sqlplus username/password @basics.sql > export.filebasics.sql包含:
set pagesize 0
set feedback off
set heading off
set linesize 400
set NULL nll
SELECT SOME_FIELDS FROM TABLE ORDER BY FIELD;
EXIT;有什么想法吗?
发布于 2013-07-29 20:27:28
shell环境对Oracle非常重要,但在使用cron时几乎不是这样。像往常一样,有几种方法可以解决这个问题。
在调用脚本时,使用完全限定的路径-一点inflexible
使用脚本设置环境的一个非常标准的方法是使用oraenv脚本,该脚本通常位于/usr/local/bin中
ORACLE_SID={your_sid}
ORAENV_ASK=NO
type oraenv >/dev/null 2>&1 || PATH=/usr/local/bin:$PATH
. oraenv
SQLPATH=$HOME/sql
export SQLPATH
do your stuff在cron行中:
10 10 * * * $HOME/.profile;$HOME/bin/your_script >$HOME/log/your_script.log 2>&1这假设.profile不是交互式的,并导出所需的环境。
https://stackoverflow.com/questions/17922688
复制相似问题