簡體   English   中英

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

[英]How to schedule Oracle DBMS Jobs in a window

我想創建一個 Oracle DBMS 作業,它在每個工作日(不是周末)從 09:00 到 20:00 每 10 分鍾運行一次。 我想知道我是否可以在作業定義的FREQ參數中做到這一點,或者我必須創建一個New Maintenance Window

似乎在提出的解決方案中,作業僅在 9 和 20 運行,並且在第一次執行后,當我運行此查詢時

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

我收到了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'

你可以使用這個:

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;

當這個調度程序負責時,我得到以下結果:

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

哪里:

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

更新:

如果您無權訪問dba_視圖,請考慮將這些前綴替換為user_ ,並從最后一個查詢的選擇列表中刪除owner列作為

select job_name, next_run_date                                  
  from user_scheduler_jobs                                               
 where JOB_NAME = 'JB_EN_LOPES'; 

我認為這是不可能的:

以下是一些 repeat_interval 示例,它們展示了日歷語法的多功能性和靈活性:

周一至周五每天晚上 10:00 運行:

FREQ=DAILY; BYDAY=MON,TUE,WED,THU,FRI; BYHOUR=22; BYMINUTE=0; BYSECOND=0;

每小時運行一次:

FREQ=HOURLY;INTERVAL=1;

每 5 分鍾運行一次:

FREQ=MINUTELY;INTERVAL=5;

每周五上午 9:00 運行(所有三個示例都等效):

FREQ=DAILY; BYDAY=FRI; BYHOUR=9; BYMINUTE=0; BYSECOND=0;
FREQ=WEEKLY; BYDAY=FRI; BYHOUR=9; BYMINUTE=0; BYSECOND=0;
FREQ=YEARLY; BYDAY=FRI; BYHOUR=9; BYMINUTE=0; BYSECOND=0;

每隔一個星期五運行:

FREQ=WEEKLY; INTERVAL=2; BYDAY=FRI;

每年第 5、10 和 15 周的星期一運行:

FREQ=YEARLY; BYWEEKNO=5,10,15; BYDAY=MON

在每個月的最后一天運行。

FREQ=MONTHLY; BYMONTHDAY=-1;

在每個月的最后一天運行:

FREQ=MONTHLY; BYMONTHDAY=-2;

在 3 月 10 日運行(兩個示例等效):

FREQ=YEARLY; BYMONTH=MAR; BYMONTHDAY=10;
FREQ=YEARLY; BYDATE=0310;

每年 1 月 10 日、11 日、12 日、13 日和 14 日運行(兩個示例都是等效的):

FREQ=YEARLY; BYDATE=0110,0111,0112,0113,0114
FREQ=YEARLY; BYDATE=0110+SPAN:5D;

每 10 天運行一次:

FREQ=DAILY; INTERVAL=10;

每天下午 4:15、5:15 和 6:15 運行:

FREQ=DAILY; BYHOUR=16,17,18; BYMINUTE=15; BYSECOND=0;

每隔一個月的第 15 天運行:

FREQ=MONTHLY; INTERVAL=2; BYMONTHDAY=15;

每月 29 日運行:

FREQ=MONTHLY; BYMONTHDAY=29;

在每個月的第二個星期三運行:

FREQ=MONTHLY; BYDAY=2WED;

在一年的最后一個星期五運行:

FREQ=YEARLY; BYDAY=-1FRI;

每 50 小時運行一次:

FREQ=HOURLY; INTERVAL=50;

在每隔一個月的最后一天運行:

FREQ=MONTHLY; INTERVAL=2; BYMONTHDAY=-1;

每個月的前三天每小時運行一次:

FREQ=HOURLY; BYMONTHDAY=1,2,3;

在一年的第 60、120 和 180 天運行:

FREQ=YEARLY; BYYEARDAY=60,120,180;

在每個月的最后一個工作日運行(假設工作日是周一到周五):

FREQ=MONTHLY; BYDAY=MON,TUE,WED,THU,FRI; BYSETPOS=-1

以下是一些更復雜的示例,它們引用了以下命名計划:

BEGIN
   sys.DBMS_SCHEDULER.create_schedule (
      schedule_name => 'COMPANY_HOLIDAYS',
      repeat_interval => 'FREQ=YEARLY; BYDATE=0704,0905,1124,1125,1225;');
   sys.DBMS_SCHEDULER.create_schedule (
      schedule_name => 'JUL4',
      repeat_interval => 'FREQ=YEARLY; BYMONTH=JUL; BYMONTHDAY=4;');
   sys.DBMS_SCHEDULER.create_schedule (
      schedule_name => 'MEM',
      repeat_interval => 'FREQ=YEARLY; BYMONTH=MAY; BYMONTHDAY=30;');
   sys.DBMS_SCHEDULER.create_schedule (
      schedule_name => 'LAB',
      repeat_interval => 'FREQ=YEARLY; BYMONTH=SEP; BYMONTHDAY=5;');
   sys.DBMS_SCHEDULER.create_schedule (
      schedule_name => 'LAST_SAT',
      repeat_interval => 'FREQ=MONTHLY; BYDAY=SAT; BYSETPOS=-1;');
   sys.DBMS_SCHEDULER.create_schedule (
      schedule_name => 'END_QTR',
      repeat_interval => 'FREQ=YEARLY; BYDATE=0331,0630,0930,1231;');
   sys.DBMS_SCHEDULER.create_schedule (
    schedule_name => 'FISCAL_YEAR',
    repeat_interval => 'FREQ=YEARLY;BYDATE=0301,0601,0901,1201;PERIODS=4;');
END;
/

在每個月的最后一個工作日運行,不包括公司假期:FREQ=MONTHLY; BYDAY=周一、周二、周三、周四、周五; 排除 = COMPANY_HOLIDAYS; BYSETPOS=-1

每周五中午和公司假期運行:FREQ=YEARLY; BYDAY=周五;BYHOUR=12; INCLUDE=COMPANY_HOLIDAYS

在這三個假期運行:7 月 4 日,陣亡將士紀念日和勞動節:JUL4,MEM,LAB

在一個月的最后一天(星期六或季度的最后一天)運行:

FREQ=MONTHLY; BYMONTHDAY=-1; INTERSECT=LAST_SAT,END_QTR

在財政年度每個季度的最后一個星期三運行:

FREQ=FISCAL_YEAR;BYDAY=-1WED

在財政年度第 2 和第 4 季度的最后一個工作日運行(假設工作日是周一到周五):

FREQ=FISCAL_YEAR;BYDAY=MON,TUE,WED,THU,FRI;BYPERIOD=2,4;BYSETPOS=-1

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM