Oracle创建定时任务,下面以创建一个每天凌晨3点钟执行的定时任务为实例。
1、创建定时任务
begin
sys.dbms_job.submit(job => 23,
what => 'PRO_JOB
;',
next_date => to_date('10-10-2018 09:36:00', 'dd-mm-yyyy hh24:mi:ss'),
interval => 'TRUNC(sysdate,''mi'') + 1/ (24*60)');
commit;
end;
PRO_JOB是你要执行的存储过程名称,多个存储过程已分号分割,注意最后面也有一个分号。
2、查询定时任务
当前用户定时任务
select
count
(*)
from
user_jobs;
有权限访问的定时任务
select
count
(*)
from
all_jobs;
整个数据库所有定时任务
select
count
(*)
from
dba_jobs;
3、手动执行定时任务
BEGIN
DBMS_JOB.RUN(643); --643为任务的ID
END;
4、任务重复运行间隔设计
4.1 在特定时间间隔后,重复运行该任务
SYSDATE+n’,n泛指一个以天为单位的时间间隔.eg:
描述 Interval参数值
每天运行一次 ‘SYSDATE+1′
每小时运行一次 ‘SYSDATE+1/24′
10分钟运行一次 ‘SYSDATE+10/(60*24)’
每30秒运行一次 ‘SYSDATE+30/(60*24*60)’
每星期运行一次 ‘SYSDATE+7′
注:此任务表达式不能保证任务的下一次运行时间在特定的日期或者时间,只能够指定一个任务两次运行之间的时间间隔。
4.2 在特定的日期和时间运行任务
定时到特定日期或时间的任务,eg:
描述 | 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)’ |