oracle设置定时任务job调度执行存储过程或pl/sql代码块

目前oracle数据库设置定时任务job调度一般有两种方式,分别是dbms_scheduler创建job调度和dbms_job创建job调度。dbms_scheduler创建job调度是在10g以后才有的,甲骨文公司为了用来替换dbms_job而提供了更强大的功能与更灵活的机制/管理。下面介绍这两种方式。

1. dbms_scheduler创建job调度。


--查询

 select * from dba_scheduler_jobs;

--创建job

 begin

 dbms_scheduler.create_job (

 job_name => 'job_myjob', --job名

 job_type => 'STORED_PROCEDURE',--job类型

 job_action => 'proc_myproc', --存储过程名

 start_date => sysdate,--开始执行时间

 repeat_interval => 'FREQ=DAILY;BYHOUR=9;BYMINUTE=30;BYSECOND=0', -- 下次执行时间,按天,每天09:30:00执行存储过程proc_myproc

 comments => '测试JOB',--注释

 auto_drop=>false  --job禁用后是否自动删除

 );

 end;

--运行

begin

dbms_scheduler.run_job('job_myjob');

end;

--启用

begin

dbms_scheduler.enable('job_myjob');

end;

--禁用

begin

dbms_scheduler.disable('job_myjob');

end;

--刪除

begin

   dbms_scheduler.drop_job(job_name => 'job_myjob',force => TRUE);

  end; 




2.dbms_job创建job调度。


--查询

select * from dba_jobs;

select * from all_jobs;

select * from user_jobs;

select * from dba_jobs_running;

-- 创建job

declare      

   job_id number;--声明一个out变量

begin

    -- 按天,每天09:30:00执行这个存储过程proc_myproc,并且输出一个job_id变量,其值为该job的ID号

   dbms_job.submit(

       job_id, --参数是输出参数,由submit()过程返回的binary_ineger,这个值用来唯一标识一个工作。一般定义一个变量接收,可以去user_jobs视图查询job值。 

       'proc_myproc;',  --参数是将被执行的PL/SQL代码块,存储过程名称等。  

       sysdate, --参数指识何时将运行这个工作。 

       'TRUNC(SYSDATE+1)+(9*60+30)/(24*60)'    --参数何时这个工作将被重执行。

    ); 

   -- 把job的ID号打印出来

   dbms_output.put_line(job_id);

end;

-- 运行job

begin

    -- 这个7为job_id,请换为你自己对应的job号

   dbms_job.run(7);

end; 

-- 启用job

begin

   dbms_job.broken(7,false);

end; 

-- 禁用job

begin

   dbms_job.broken(7,true);

end; 

-- 删除一个job

begin

   dbms_job.remove(7);

end; 


猜你喜欢

转载自wangjinlongaisong-126-com.iteye.com/blog/2357371