출처 :  http://download.oracle.com/docs/cd/B28359_01/server.111/b28310/scheduse004.htm#i1023132



Using the Scheduler Calendaring Syntax


The primary method of setting how often a job will repeat is by setting the repeat_interval attribute with a Scheduler calendaring expression. See
Oracle Database PL/SQL Packages and Types Reference for a detailed description of the calendaring syntax for repeat_interval as well as the CREATE_SCHEDULE procedure.




Examples of Cal
endaring Expressions

The following examples illustrate simple repeat intervals. For simplicity, it is assumed that there is no contribution to the evaluation results by the start date.


Run every Friday. (All three examples are equivalent.)
FREQ=DAILY; BYDAY=FRI;
FREQ=WEEKLY; BYDAY=FRI;
FREQ=YEARLY; BYDAY=FRI;


Run every other Friday.
FREQ=WEEKLY; INTERVAL=2; BYDAY=FRI;


Run on the last day of every month.
FREQ=MONTHLY; BYMONTHDAY=-1;


Run on the next to last day of every month.
FREQ=MONTHLY; BYMONTHDAY=-2;


Run on March 10th. (Both examples are equivalent)
FREQ=YEARLY; BYMONTH=MAR; BYMONTHDAY=10;
FREQ=YEARLY; BYDATE=0310;


Run every 10 days.
FREQ=DAILY; INTERVAL=10;


Run daily at 4, 5, and 6PM.
FREQ=DAILY; BYHOUR=16,17,18;


Run on the 15th day of every other month.
FREQ=MONTHLY; INTERVAL=2; BYMONTHDAY=15;


Run on the 29th day of every month.
FREQ=MONTHLY; BYMONTHDAY=29;


Run on the second Wednesday of each month.
FREQ=MONTHLY; BYDAY=2WED;


Run on the last Friday of the year.
FREQ=YEARLY; BYDAY=-1FRI;


Run every 50 hours.

FREQ=HOURLY; INTERVAL=50;


Run on the last day of every other month.
FREQ=MONTHLY; INTERVAL=2; BYMONTHDAY=-1;


Run hourly for the first three days of every month.
FREQ=HOURLY; BYMONTHDAY=1,2,3;



Here are some more complex repeat intervals:

Run on the last workday of every month (assuming that workdays are Monday through Friday).
FREQ=MONTHLY; BYDAY=MON,TUE,WED,THU,FRI; BYSETPOS=-1


Run on the last workday of every month, excluding company holidays. (This example references an existing named schedule called Company_Holidays.)
FREQ=MONTHLY; BYDAY=MON,TUE,WED,THU,FRI; EXCLUDE=Company_Holidays; BYSETPOS=-1


Run at noon every Friday and on company holidays.
FREQ=YEARLY;BYDAY=FRI;BYHOUR=12;INCLUDE=Company_Holidays


Run on these three holidays: July 4th, Memorial Day, and Labor Day. (This example references three existing named schedules—JUL4, MEM, and LAB—where each defines a single date corresponding to a holiday.)
JUL4,MEM,LAB




Examples of Calendaring Expression Evaluation

A repeat interval of "FREQ=MINUTELY;INTERVAL=2;BYHOUR=17; BYMINUTE=2,4,5,50,51,7;" with a start date of 28-FEB-2004 23:00:00 will generate the following schedule:

SUN 29-FEB-2004 17:02:00
SUN 29-FEB-2004 17:04:00
SUN 29-FEB-2004 17:50:00
MON 01-MAR-2004 17:02:00
MON 01-MAR-2004 17:04:00
MON 01-MAR-2004 17:50:00
...


A repeat interval of "FREQ=MONTHLY;BYMONTHDAY=15,-1" with a start date of 29-DEC-2003 9:00:00 will generate the following schedule:

WED 31-DEC-2003 09:00:00
THU 15-JAN-2004 09:00:00
SAT 31-JAN-2004 09:00:00
SUN 15-FEB-2004 09:00:00
SUN 29-FEB-2004 09:00:00
MON 15-MAR-2004 09:00:00
WED 31-MAR-2004 09:00:00
...


A repeat interval of "FREQ=MONTHLY;" with a start date of 29-DEC-2003 9:00:00 will generate the following schedule. (Note that because there is no BYMONTHDAY clause, the day of month is retrieved from the start date.)

MON 29-DEC-2003 09:00:00
THU 29-JAN-2004 09:00:00
SUN 29-FEB-2004 09:00:00
MON 29-MAR-2004 09:00:00
 

+ Recent posts