在c:temp下写了一个文件dbrman.bat,内容如下:
rman target / cmdfile=dbbak.sql log=dbbak.txt append
执行时错误如下:
SQL> exec dbms_scheduler.run_job('my_job_dbbak');
BEGIN dbms_scheduler.run_job('my_job_dbbak'); END;
*
第 1 行出现错误:
ORA-27369: 类型为 EXECUTABLE 的作业失败, 退出代码: 函数不正确。
ORA-06512: 在 "SYS.DBMS_ISCHED", line 150
ORA-06512: 在 "SYS.DBMS_SCHEDULER", line 441
ORA-06512: 在 line 1
网上搜了一下大部分都说由于服务OracleJobSchedulerORCL没有启动,可这个服务实际已经启动了,尝试吧dbrman.bat内容修改为
dir c: >c:tempa.txt和exp test1/test1 file=c:tempa.dmp log=c:tempa.log 都可以成功执行,于是断定是脚本rman target / cmdfile=dbbak.sql log=dbbak.txt append自身的问题,搜索了一下dbbak.txt 发现位于E:oracleproduct10.2.0db_1database下:
E:oracleproduct10.2.0db_1database>dir dbbak.txt
驱动器 E 中的卷没有标签。
卷的序列号是 F6E5-4B31
E:oracleproduct10.2.0db_1database 的目录
01/16/2010 08:37 PM 46,758 dbbak.txt
1 个文件 46,758 字节
0 个目录 4,000,104,448 可用字节
E:oracleproduct10.2.0db_1database>
问题已经清楚了,脚本里面缺少绝对路径,调整如下:
rman target / cmdfile=c:tempdbbak.sql log=dbbak.txt append
之后成功执行:
SQL> exec dbms_scheduler.run_job('my_job_dbbak');
PL/SQL 过程已成功完成。
SQL>
而且在上面测试的过程中OracleJobSchedulerORCL始终都没有启动,所以说在调用外部job时OracleJobSchedulerORCL也不是必须要启动的
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/19602/viewspace-1030628/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/19602/viewspace-1030628/