如何在窗口中安排Oracle DBMS作业

en *_*pes 3 oracle plsql dbms-scheduler oracle11g

我想创建一个Oracle DBMS作业,每10分钟从09:00到20:00每周(不是在周末)运行.我想知道我是否可以FREQ在作业定义的参数中执行此操作,或者我必须创建一个New Maintenance Window.

似乎在提出的解决方案中,作业仅在9和20运行,并且在第一次执行后,当我运行此查询时

select owner, job_name, next_run_date 
from dba_scheduler_jobs 
where JOB_NAME = 'GET_INVOICES_JOB';
Run Code Online (Sandbox Code Playgroud)

我有 09/10/17 20:01:27,000000000 EUROPE/MADRID

'freq=minutely; interval=10; byhour=9,20; byday=MON,TUE,WED,THU,FRI; exclude=Company_Holidays; bysetpos=-1'
Run Code Online (Sandbox Code Playgroud)

Bar*_*han 5

你可以用这个:

begin
dbms_scheduler.create_job (
   job_name           =>  'jb_en_lopes',
   job_type           =>  'STORED_PROCEDURE',
   job_action         =>  'pr_en_lopes',
   start_date         =>  '09-oct-2017 09:00:00 am',
   repeat_interval    =>  'freq=minutely; interval=10; byhour=9,10,11,12,13,14,15,16,17,18,19,20; byday=MON,TUE,WED,THU,FRI;',
   enabled            =>  true);
end;
Run Code Online (Sandbox Code Playgroud)

当这个负责的调度程序我得到以下结果:

select * 
  from dba_scheduler_job_log l
 where l.job_name = 'JB_EN_LOPES'
 order by l.log_date desc;

 LOG_ID LOG_DATE                            OPERATION   STATUS

1051594 10-OCT-17 09.59.01.197420 AM +03:00    RUN      SUCCEEDED  
1051592 10-OCT-17 09.58.02.229724 AM +03:00    RUN      SUCCEEDED  
1051590 10-OCT-17 09.57.03.177907 AM +03:00    RUN      SUCCEEDED  
1051588 10-OCT-17 09.56.01.197341 AM +03:00    RUN      SUCCEEDED
Run Code Online (Sandbox Code Playgroud)

地点:

select owner, job_name, next_run_date                                  
  from dba_scheduler_jobs                                               
 where JOB_NAME = 'JB_EN_LOPES'; 

 OWNER    JOB_NAME       NEXT_RUN_DATE

 myschema JB_EN_LOPES   10-OCT-17 08.00.00.194958 PM +03:00
Run Code Online (Sandbox Code Playgroud)