时间:2021-07-01 10:21:17 帮助过:45人阅读
过程已创建。
创建JOB
描述 Interval参数值
每天运行一次 ‘SYSDATE + 1‘
每小时运行一次 ‘SYSDATE + 1/24‘
每10分钟运行一次 ‘SYSDATE + 10/(60*24)‘
每30秒运行一次 ‘SYSDATE + 30/(60*24*60)‘
每隔一星期运行一次 ‘SYSDATE + 7‘
定时到特定日期或时间的任务例子
描述 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)‘
将要执行的任务写成存储过程或其他的数据库可执行的pl/sql程序段
例如,我们已经建立了一个存储过程,其名称为my_job,在sql/plus中以scott用户身份登录,执行如下命令:
sql> variable n number;
sql> begin
dbms_job.submit(:n‘my_job;’,sysdate,
‘sysdate+1/360’);
commit;
end;
/
系统提示执行成功。
Sql> print :n;
系统打印此任务的编号,例如结果为300。
如上,我们创建了一个每隔4分钟执行一次的任务号为300的任务。可以通过Oracle提供的数据字典user_jobs察看该任务的执行情况:
sql> select job,next_date,next_sec,failures,broken from user_jobs;
执行结果如下:
job next_date next_sec failures broken
300 2000/10/10 11:45:15 0 N
这表示任务号为300的任务,下一次将在2000/10/10
11:45:15执行,此任务的执行失败记录为0次。注意:当执行job出现错误时,Oracle将其记录在日志里,失败次数每次自动加1。当执行失败次
数达到16时,Oracle就将该job标志为broken。此后,Oracle不再继续执行它,直到用户调用过
例子:
begin sys.dbms_job.submit(job => :job, what => ‘ADD_PLY_INTOXG;‘, next_date => to_date(‘01-01-4000‘, ‘dd-mm-yyyy‘), interval => ‘to_date(to_char(SYSDATE,‘‘yyyy/mm/dd hh24‘‘)||‘‘:00:00‘‘,‘‘yyyy/mm/dd hh24:mi:ss‘‘)+65/1440‘); sys.dbms_job.broken(job => :job, broken => true, next_date => to_date(‘01-01-4000‘, ‘dd-mm-yyyy‘)); commit; end; /
oracle定时任务(dbms_job)
标签:特定 语法 targe arc cot 进程 管理器 执行时间 知识库