oracle DBMS作业

今天下午有时间就自己摸索了一下dbms作业,也就是定时任务。下面就根绝这些做一下记录:

DBMS_JOB可以设定一个定时的任务,每隔固定的时间重复执行一个存储过程,用法是:

dbms_job.submit(jobid,'myjob;',sysdate,'sysdate+1/24');
这一行的代码的意思是:作业的编号是:jobid,执行的存储过程是:mojob,开始执行的时间是:sysdate,下次执行的间隔时间是:1/24 (天)。

也不多说废话了,直接上例子:

--创建测试表
create table test1(aa date);
--创建存储过程
create or replace procedure mojob 
as
begin
  insert into test1(aa) values(sysdate);
end;
/
--开始任务
declare 
jobid number;
begin
dbms_job.submit(jobid,'myjob;',sysdate,'sysdate+1/43200');
commit;
dbms_output.put_line(jobid);
end;
/
如果要关闭这个任务的话可以用:

exec dbms_job.remove(47);

如果不记得jobid也没关系,可以查询当前所有的作业,然后判断要关闭的,查询语句为:

select * from all_jobs;



你可能感兴趣的:(oracle,dbms_job,作业)