加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

oracle 创建job

发布时间:2020-12-12 16:21:00 所属栏目:百科 来源:网络整理
导读:目前oracle数据库设置定时任务job调度一般有两种方式,分别是 dbms_scheduler创建job调度 和 dbms_job创建job调度 。dbms_scheduler创建job调度是在10g以后才有的,甲骨文公司为了用来替换dbms_job而 提供了更强大的功能与更灵活的机制/管理。下面介绍这两种

目前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;


 
 

总结:推荐大家使用dbms_scheduler来创建job调度。job调度可以定时执行PL/SQL代码块,存储过程等。

本文出自 “zhanglunc” 博客,请务必保留此出处http://www.52php.cn/article/p-tntaqnpy-gb.html

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读