oracle定时推送消息,oracle定时任务调度(dbms_scheduler案例)

数据库层任务调度中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'

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值