数据库层任务调度中mysql有event,postgreSQL有pgAgent(插件实现),那么oracle有dbms_job/dbms_scheduler。
oracle10g以后推荐使用dbms_scheduler,据说比dbms_job更加健壮,日志或者是减少操作系统依赖更强等等,具体可以去看看相关资料,所以以它为例:
BEGIN
FOR V_JOB IN (SELECT JOB_NAME
FROM USER_SCHEDULER_JOBS K
WHERE K.JOB_NAME IN ('TEST_JOB')
) LOOP
DBMS_SCHEDULER.DROP_JOB(V_JOB.JOB_NAME);
END LOOP;
FOR V_PROG IN (SELECT PROGRAM_NAME
FROM USER_SCHEDULER_PROGRAMS S
WHERE S.PROGRAM_NAME IN ('TEST_PROGRAM')
) LOOP
DBMS_SCHEDULER.DROP_PROGRAM(V_PROG.PROGRAM_NAME);
END LOOP;
--定义PROGRAM
DBMS_SCHEDULER.CREATE_PROGRAM(PROGRAM_NAME => 'TEST_PROGRAM',
PROGRAM_TYPE => 'STORED_PROCEDURE',
PROGRAM_ACTION => '要调用的存储过程',
NUMBER_OF_ARGUMENTS => 0,
ENABLED => FALSE,
COMMENTS => NULL);
--定义参数(根据调用的存储过程而定)
DBMS_SCHEDULER.DEFINE_PROGRAM_ARGUMENT(PROGRAM_NAME => 'TEST_PROGRAM',
ARGUMENT_NAME => 'in_param',
ARGUMENT_POSITION => 1,
ARGUMENT_TYPE => 'NUMBER',
DEFAULT_VALUE => -1);
-- 启用PROGRAM
DBMS_SCHEDULER.ENABLE(NAME => 'TEST_PROGRAM');
--定义JOB
DBMS_SCHEDULER.CREATE_JOB(JOB_NAME => 'TEST_JOB',
PROGRAM_NAME => 'TEST_PROGRAM',
COMMENTS => '如每天凌晨2点执行',
REPEAT_INTERVAL => 'FREQ=DAILY; BYHOUR=02; BYMINUTE=00;',
AUTO_DROP => FALSE,
ENABLED => FALSE);
--启用JOB
DBMS_SCHEDULER.ENABLE(NAME => 'TEST_JOB');
END;
/
REPEAT_INTERVAL可选参数:
YEARLY(年), MONTHLY(月), WEEKLY(周), DAILY(日), HOURLY(时), MINUTELY(分), SECONDLY(秒)等单位。
INTERVAL 关键字用来指定间隔的频繁,可指定的值的范围从1-999。
BYHOUR 指定一天中的小时。可指定的值的范围从1-24。16,17,18就表示每天下午的4、5、6点。
BYDAY 关键字用来指定每周的哪天运行。
BYMONTHDAY 关键字用来指定每月中的哪一天。-1 表示每月最后一天。
BYMONTH 关键字用来指定每年的月份。
BYDATE 指定日期。0310就表示3月10日。
REPEAT_INTERVAL例子:
运行每星期五。(所有这三个例子是等价的。)
FREQ=DAILY; BYDAY=FRI;
FREQ=WEEKLY; BYDAY=FRI;
FREQ=YEARLY; BYDAY=FRI;
设置任务隔一周运行一次,并且仅在周5运行:
FREQ=WEEKLY; INTERVAL=2; BYDAY=FRI;
在每月的最后一天运行
FREQ=MONTHLY; BYMONTHDAY=-1;
三月十日开。(两个例子是等价的)
FREQ=YEARLY; BYMONTH=MAR; BYMONTHDAY=10;
FREQ=YEARLY; BYDATE=0310;
设置任务每10隔天运行:
REPEAT_INTERVAL => 'FREQ=DAILY; INTERVAL=10';
设置任务在每天的下午4、5、6点时运行:
REPEAT_INTERVAL => 'FREQ=DAILY; BYHOUR=16,17,18';
设置任务在每月29日运行:
REPEAT_INTERVAL => 'FREQ=MONTHLY; BYMONTHDAY=29';
设置任务在每年的最后一个周5运行:
REPEAT_INTERVAL => 'FREQ=YEARLY; BYDAY=-1FRI';
设置任务每隔50个小时运行:
REPEAT_INTERVAL => 'FREQ=HOURLY; INTERVAL=50';
每隔2小时运行一次job
repeat_interval => 'FREQ=HOURLY; INTERVAL=2'
每天运行一次job
repeat_interval => 'FREQ=DAILY'
每周的1,3,5运行job
repeat_interval => 'FREQ=WEEKLY; BYDAY=MON,WED,FRI"
每年的3,6,9,12月的30号运行job
repeat_interval => 'FREQ=YEARLY; BYMONTH=MAR,JUN,SEP,DEC; BYMONTHDAY=30'