数据库层任务调度中mysql有event,postgreSQL有pgAgent(插件实现),那么oracle有dbms_job/dbms_scheduler。mysql
oracle10g之后推荐使用dbms_scheduler,听说比dbms_job更加健壮,日志或者是减小操做系统依赖更强等等,具体能够去看看相关资料,因此以它为例:sql
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就表示天天下午的四、五、6点。 BYDAY 关键字用来指定每周的哪天运行。 BYMONTHDAY 关键字用来指定每个月中的哪一天。-1 表示每个月最后一天。 BYMONTH 关键字用来指定每一年的月份。 BYDATE 指定日期。0310就表示3月10日。
REPEAT_INTERVAL例子:oracle
运行每星期五。(全部这三个例子是等价的。) 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'; 设置任务在天天的下午四、五、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'