加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Oracle创建定时任务

发布时间:2020-12-12 18:46:58 所属栏目:百科 来源:网络整理
导读:Oracle创建定时任务,下面以创建一个每天凌晨3点钟执行的定时任务为实例。 1、创建定时任务 DECLARE JOB_ID PLS_INTEGER;BEGIN SYS.DBMS_JOB.SUBMIT(JOB = JOB_ID,WHAT = 'PRO_JOB;',INTERVAL = 'TRUNC(SYSDATE) + 1 + 3 / (24)'); COMMIT;END; PRO_JOB是你
描述 Lnterval参数值 每天午夜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)’

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

Oracle创建定时任务,下面以创建一个每天凌晨3点钟执行的定时任务为实例。

1、创建定时任务

DECLARE
  JOB_ID PLS_INTEGER;
BEGIN
  SYS.DBMS_JOB.SUBMIT(JOB => JOB_ID,WHAT => 'PRO_JOB;',INTERVAL => 'TRUNC(SYSDATE) + 1 + 3 / (24)');
  COMMIT;
END;

PRO_JOB是你要执行的存储过程名称,多个存储过程已分号分割,注意最后面也有一个分号。

2、手动执行定时任务

BEGIN  
    DBMS_JOB.RUN(643); --643为任务的ID  
END;

3、任务重复运行间隔设计

3.1在特定时间间隔后,重复运行该任务

SYSDATE+n’,n泛指一个以天为单位的时间间隔.eg:

描述 Interval参数值
每天运行一次 ‘SYSDATE+1′
每小时运行一次 ‘SYSDATE+1/24′
10分钟运行一次 ‘SYSDATE+10/(60*24)’
每30秒运行一次 ‘SYSDATE+30/(60*24*60)’
每星期运行一次 ‘SYSDATE+7′
注:此任务表达式不能保证任务的下一次运行时间在特定的日期或者时间,只能够指定一个任务两次运行之间的时间间隔。

3.2在特定的日期和时间运行任务

定时到特定日期或时间的任务,eg:

    推荐文章
      热点阅读