Oracle设置定时任务JOB调度执行存储过程或PL/SQL代码块

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;
Comments are closed.