当前位置:Gxlcms > 数据库问题 > oracle定时任务(dbms_job)

oracle定时任务(dbms_job)

时间:2021-07-01 10:21:17 帮助过:45人阅读

create or replace procedure test as begin insert into a values(sysdate); end;

过程已创建。

创建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   进程   管理器   执行时间   知识库   

人气教程排行