2

我需要安排从 0600 到 1800 的作业。作业应该每两小时运行一次。例如 0800、1000、1200、1400、1600、1800。

这是我迄今为止设法完成的代码:

DECLARE
     l_id binary_integer;
     begin
       sys.dbms_job.submit(job => l_id, what => 'integration_export;', interval => 'TRUNC(SYSDATE,''hh24'')+0/24/60');
       sys.dbms_output.put_line(l_id);    
end; 

当然,这将在每 2 小时后运行一次作业,而不会在 1801 - 0759 处停止。如何添加此限制?我认为的一件事是创建另一个调度程序,该程序在 1801 唤醒并更改此作业的 NEXT_DATE。但是,我想知道这是否是一个好主意。

有什么建议么?

提前致谢 :-)

4

2 回答 2

7

dbms_job老了。我建议您改用dbms_scheduler(在 Oracle 10g 中引入)。

dbms_scheduler.create_job(job_name        => 'YOUR_JOB',
                          job_type        => 'PLSQL_BLOCK', 
                          job_action      => 'integration_export;',
                          start_date      => systimestamp,
                          repeat_interval => 'freq=hourly; byhour=8,10,12,14,16,18; byminute=0; bysecond=0;',
                      enabled         => true,
                      auto_drop       => false,
                      comments        => 'some comment about the job');
于 2013-01-15T12:13:25.513 回答
2

使用高级 dbms_scheduler 代替 dmbs_job。这是一个例子:

begin
  DBMS_SCHEDULER.create_job (
    job_name        => 'Integration_export',
    job_type        => 'PLSQL_BLOCK',
    job_action      => 'integration_export;',
    start_date      => SYSTIMESTAMP,
    enabled         => TRUE,
    repeat_interval => 'freq=daily; byhour=6,8,10,12,14,16,18; byminute=0; bysecond=0');
end;
/
于 2013-01-15T12:12:58.023 回答