文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2024-04-02 19:55

关注

   目前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代码块,存储过程等。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯