Oracle中的定时任务实例教程(oracle定时任务broken)全程干货

随心笔谈3年前发布 admin
228 0 0

文章摘要

这篇文章详细介绍了如何在数据库中设置INTERVAL参数,以在特定时间点触发操作。文章列出了多种定时任务的设置方式,包括每天、每周、每月、每个季度、每个半年以及每年的定时执行。每个定时任务都给出了具体的INTERVAL表达式,例如: - **每天定时执行**:如每天午夜12点,INTERVAL设为 `TRUNC(SYSDATE + 1) + 12/24`。 - **每周定时执行**:如每周一凌晨1点,INTERVAL设为 `TRUNC(NEXT_DAY(SYSDATE, 'TUESDAY')) + 1/24`。 - **每月定时执行**:如每月1日凌晨1点,INTERVAL设为 `TRUNC(LAST_DAY(SYSDATE)) + 1 + 1/24`。 - **每个季度定时执行**:如每季度第一天的午夜12点,INTERVAL设为 `TRUNC(ADD_MONTHS(SYSDATE + 2/24, 3), 'Q') - 1/24`。 文章还提到了如何根据需求调整执行时间,例如将INTERVAL从1秒增加到10秒,或从1分钟增加到10分钟。这些设置方法帮助用户根据具体需求实现精确的定时任务。

描述 INTERVAL参数值
每天午夜12点 TRUNC(SYSDATE + 1)
每天早上8点30分 TRUNC(SYSDATE + 1) + (8*60+30)/(24*60)
每星期二中午12点 NEXT_DAY(TRUNC(SYSDATE ), ”TUESDAY” ) + 12/24
每个月第一天的午夜12点 TRUNC(LAST_DAY(SYSDATE ) + 1)
每个季度最后一天的晚上11点 TRUNC(ADD_MONTHS(SYSDATE + 2/24, 3 ), ‘Q’ ) -1/24
每星期六和日早上6点10分 TRUNC(LEAST(NEXT_DAY(SYSDATE, ”SATURDAY”), NEXT_DAY(SYSDATE, “SUNDAY”))) + (6×60+10)/(24×60)
每秒钟执行次

Interval=> sysdate + 1/(24 * 60 * 60)

如果改成sysdate + 10/(24 * 60 * 60)就是10秒钟执行次

每分钟执行
Interval=> TRUNC(sysdate,’mi’) + 1/ (24*60)

如果改成TRUNC(sysdate,’mi’) + 10/ (24*60) 就是每10分钟执行次

每天定时执行
例如:每天的凌晨1点执行
Interval=> TRUNC(sysdate) + 1 +1/ (24)

每周定时执行
例如:每周一凌晨1点执行
Interval=> TRUNC(next_day(sysdate,’星期一’))+1/24

每月定时执行
例如:每月1日凌晨1点执行
Interval=>TRUNC(LAST_DAY(SYSDATE))+1+1/24

每季度定时执行
例如每季度的第一天凌晨1点执行
Interval=> TRUNC(ADD_MONTHS(SYSDATE,3),’Q’) + 1/24

每半年定时执行
例如:每年7月1日和1月1日凌晨1点
Interval=> ADD_MONTHS(trunc(sysdate,’yyyy’),6)+1/24

每年定时执行
例如:每年1月1日凌晨1点执行
Interval=>ADD_MONTHS(trunc(sysdate,’yyyy’),12)+1/24

© 版权声明

相关文章