• oracle中job定时器任务


     对于DBA来说,经常要数据库定时的自动执行一些脚本,或做数据库备份,或做数据的提炼,或做数据库的性能优化,包括重建索引等等的工作。但是,Oracle定时器Job时间的处理上,千变万化,今天我把比较常用写法汇总如下:

    在总结之前,先把Job的参数一一说明一下:

    job参数是由Submit()过程返回的binary_ineger。这个值用来唯一标识一个工作;

    what参数是将被执行的PL/SQL代码块;

    next_date参数指识何时将运行这个工作。写Job的时候可以不指定该值;

    interval参数何时这个工作将被重执行。

    其中Interval这个值是决定Job何时,被重新执行的关键。

    例如:有存储过程 p_dosomethings,需要被不同的时间间隔执行。

     declare   
       jobno number;   
     begin   
       dbms_job.submit(
         jobno,
         'p_dosomething;',  --what
         to_date('20090101020000','yyyy-mm-dd hh24:mi:ss'),--next_date,可以不填
         'Interval时间字符串'--interval,关键设置
       );   
      commit;   

    end; 

    建一个JOB,定时执行不带参数的函数:

    DECLARE

      job        BINARY_INTEGER;  --任务ID

      v_begin    DATE;  --开始时间

      v_interval VARCHAR2(50);  --时间间隔
    BEGIN
      v_begin    := TRUNC(SYSDATE) + 12/24; --<当前日期的 12:00>
      v_interval := 'SYSDATE +1';     --<每隔24小时 执行一次>
      DBMS_JOB.submit(job,                  --JOB编号
                      sg_wf_zxcf_syn;',     --what值
                      v_begin,               --下一个日期    
                      v_interval,            --间隔
                      FALSE,
                      0,                     --合计时间                       
                      FALSE);
      DBMS_OUTPUT.put_line('JOB(任务)编号:' || job);
      COMMIT;
    END;

     //常见的时间写法

    1、 每分钟执行

    Interval => TRUNC(sysdate,’mi’) + 1 / (24*60)

    2、 每天定时执行

    例如:每天的凌晨2点执行

    Interval => TRUNC(sysdate) + 1 +2 / (24)

    3、 每周定时执行

    例如:每周一凌晨2点执行

    Interval => TRUNC(next_day(sysdate,2))+2/24 --星期一,一周的第二天

    4、 每月定时执行

    例如:每月1日凌晨2点执行

    Interval =>TRUNC(LAST_DAY(SYSDATE))+1+2/24

    5、 每季度定时执行

    例如每季度的第一天凌晨2点执行

    Interval => TRUNC(ADD_MONTHS(SYSDATE,3),'Q') + 2/24

    6、 每半年定时执行

    例如:每年7月1日和1月1日凌晨2点

    Interval => ADD_MONTHS(trunc(sysdate,'yyyy'),6)+2/24

    7、 每年定时执行

    例如:每年1月1日凌晨2点执行

    Interval =>ADD_MONTHS(trunc(sysdate,'yyyy'),12)+2/24

      8、 SQL语句

    -------------查询JOB-----------------
    select job, what, next_date, next_sec, sysdate, failures, broken,interval
      from user_jobs a;

    -------------添加JOB-----------------
    variable n number;

    begin
      dbms_job.submit(:n, 'MY_JOP;', sysdate,'sysdate+2/(24*60*60)');
      commit;
    end;

    -------------修改JOB-----------------
    begin
      dbms_job.change(62 ,'MY_JOP;', sysdate,'sysdate+2/(24*60)' );
      commit;
    end;

    begin
      dbms_job.change(62 ,'MY_JOP;', to_date('2011-08-01 22:00:00', 'yyyy-mm-dd hh24:mi:ss'),'sysdate+1');
      commit;
    end;


    -------------删除JOB-----------------
    begin
     dbms_job.remove(41);
    end;

    -------------运行Job-----------------------
    begin
     dbms_job.run(41);
    end;

     9、JOB案例:

     建一个JOB,定时执行带参数的函数:

    DECLARE
      job        BINARY_INTEGER;  --任务ID
      v_begin    DATE;   --开始时间
      v_interval VARCHAR2(50);  --时间间隔
    BEGIN
      v_begin    := TRUNC(SYSDATE) + 12/24;  --<当前日期的 12:00>
      v_interval := 'SYSDATE +1';     --<每隔24小时 执行一次>
      DBMS_JOB.submit(job,                    --JOB编号
                      'declare V_SUMSG varchar(200);V_SUMWF varchar(200); V_SUMZXCF varchar(200); begin sg_wf_zxcf_syn(V_SUMSG,V_SUMWF,V_SUMZXCF);end;',    --what值
                      v_begin,              --下一个日期    
                      v_interval,            --间隔
                      FALSE,
                      0,                     --合计时间                       
                      FALSE);
      DBMS_OUTPUT.put_line('JOB(任务)编号:' || job);
      COMMIT;
    END;
  • 相关阅读:
    三级听力
    查找算法集(数组实现、链表实现)(转贴)
    男人一生必须要做10件事(转载)
    经典源码网(集合)
    ubuntu8.04下mplayer错误error:could not open required directshow codec drvc.dll
    asp.net 访问 iis的权限 问题
    OPENROWSET 说明
    vb多线程问题
    收缩数据库日志文件(转贴)
    Update 两个表之间数据更新
  • 原文地址:https://www.cnblogs.com/weiyi1314/p/9041361.html
Copyright © 2020-2023  润新知