ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 使用 DBMS_SCHEDULER执行外部命令

使用 DBMS_SCHEDULER执行外部命令

原创 Linux操作系统 作者:lsq_008 时间:2012-04-28 16:45:36 0 删除 编辑
使用  DBMS_SCHEDULER可以很方便的执行操作系统下的命令或脚本,这样在执行一些定时脚本时就不需要依赖于操作系统的计划任务或crontab了。如下,创建定时执行exp导出的定时任务:
一。创建job
1.创建job,执行定时exp导出
BEGIN
DBMS_SCHEDULER.CREATE_JOB(
   job_name          =>  'JOB_EXP_XJNY_CHARISMA',
   job_type          =>  'EXECUTABLE',
   job_action        =>  'C:\oracle\product\11.2.0\dbhome_1\bin\exp xjny/xjny tables=at_naizan file=C:\工作相关\数据导入\at_naizan.dmp',
   start_date        =>  SYSDATE,
--  repeat_interval   =>  'FREQ = DAILY; INTERVAL = 1');
   repeat_interval   =>  'FREQ = MINUTELY; INTERVAL = 3');
END;
/


2. 创建job后,需要启用该job
BEGIN
DBMS_SCHEDULER.ENABLE ('JOB_EXP_XJNY_CHARISMA');
END;
/


3.禁用job
BEGIN
DBMS_SCHEDULER.DISABLE ('JOB_EXP_XJNY_CHARISMA');
END;
/

4.删除job
BEGIN
   DBMS_SCHEDULER.DROP_JOB('JOB_EXP_XJNY_CHARISMA');
END;
/


二 .查看scheduler job的执行日志

select OWNER,JOB_NAME,ENABLED,JOB_ACTION,RUN_COUNT,LAST_START_DATE,NEXT_RUN_DATE
from  dba_SCHEDULER_JOBs
where job_name='JOB_EXP_XJNY_CHARISMA';

SELECT OWNER,JOB_NAME,LOG_DATE,OPERATION,STATUS,USER_NAME
FROM DBA_SCHEDULER_JOB_LOG WHERE JOB_NAME='JOB_EXP_XJNY_CHARISMA';

select * from  DBA_SCHEDULER_JOB_RUN_DETAILS WHERE JOB_NAME = 'JOB_EXP_XJNY_CHARISMA';

在windows下需要开启OracleJobSchedulerSID的服务才能成功执行相应的job,否则报27370错误,如下:
"ORA-27370: 作业的从属进程无法启动类型为 EXECUTABLE 的作业
ORA-27300: 操作系统系统相关操作: accessing job scheduler service 失败, 状态为: 2
ORA-27301: 操作系统故障消息: 系统找不到指定的文件。
ORA-27302: 错误发生在: sjsec 6a
ORA-27303: 附加信息: 系统找不到指定的文件。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10972173/viewspace-722443/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论
十余年大型金融及电信系统数据库管理经验,曾服务于中国建设银行、中国移动。对oracle,mysql数据库有深入了解。 擅长python开发,独立开发了开源数据库自动化监控运维平台Power Monitor。

注册时间:2008-02-29

  • 博文量
    323
  • 访问量
    1223588