设为首页 收藏本站
查看: 3629|回复: 0

[经验分享] Oracle 定时任务dbms_scheduler

[复制链接]
累计签到:2 天
连续签到:1 天
发表于 2018-9-6 09:55:32 | 显示全部楼层 |阅读模式
  1. 简介
  在Oracle 10g之前,我们通过DBMS_JOB来管理定时任务;
  而10g之后,则推荐使用DBMS_SCHEDULER来管理定时任务,因为它提供了更强大的功能和灵活的机制。
  2. 需要的权限
  CREATE JOB          -- (必须, 要执行DBMS_SCHEDULER, 需要有create job权限)
  CREATE EXTERNAL JOB -- (可选, 创建执行操作系统命令的job时需要)
  # 查询用户所拥有的角色以及角色所包含的权限
  select * from role_sys_privs where role in (
  select granted_role from dba_role_privs where grantee='SCOTT'
  ) order by role;
  # 查询直接授予用户的权限
  select * from dba_sys_privs where grantee='SCOTT';
  3. 一个简单的Demo
  3.1 创建JOB

  • create table test_t1(id int, create_date date);  
    create or replace procedure test_p1
      
    is
      
      v_maxId test_t1.id%type := 1;
      
    begin
      
      select nvl(max(id), 0) into v_maxId from test_t1;
      
      insert into test_t1 values(v_maxId + 1, sysdate);
      
      commit;
      
    end test_p1;
      
    /
      
    declare
      
      v_count int := 0;
      
    begin
      
      select count(*) into v_count from user_scheduler_jobs where job_name='TEST_JOB1';
      
      if v_count > 0 then
      
        dbms_scheduler.drop_job('TEST_JOB1');
      
      end if;
      
      dbms_scheduler.create_job (
      
        job_name        => 'test_job1',
      
        job_type        => 'STORED_PROCEDURE',
      
        job_action      => 'TEST_P1',
      
        start_date      => sysdate,
      
        repeat_interval => 'FREQ=MINUTELY;INTERVAL=1',
      
        enabled         => true
      
      );
      
    end;
      
    /

  • job_name        : 必选, 任务名称  
    job_type        : 必选, 任务类型(
      
                        PLSQL_BLOCK,      -- 执行一个PL/SQL匿名快
      
                        STORED_PROCEDURE, -- 执行一个存储过程
      
                        EXECUTABLE,       -- 执行一个外部程序
      
                        CHAIN             -- 执行一个CHAIN
      
                      )
      
    job_action      : 必选, 任务内容, 与job_type配合使用
      
    start_date      : 可选, 首次执行时间, 为空时表示立即执行
      
    repeat_interval : 可选, 执行频率, 为空时表示只执行一次(
      
                        FREQ=MINUTELY; -- 表示间隔单位, 可选值有YEARLY, MONTHLY, WEEKLY, DAILY, HOURLY, MINUTELY, SECONDLY
      
                        INTERVAL=1     -- 表示间隔周期
      
                      )
      
    enabled         : 可选, 是否启用任务
  详细参数可参考: http://docs.oracle.com/cd/E11882_01/appdev.112/e40758/d_sched.htm#ARPLS72960
  3.2 查看JOB执行情况
  -- 查看已创建的JOB
  select job_name, job_type, enabled, state from user_scheduler_jobs;
  -- 查看JOB运行日志
  select log_id, log_date, status from user_scheduler_job_run_details where job_name='TEST_JOB1';
  3.3 删除JOB
  exec dbms_scheduler.drop_job('TEST_JOB1');
  # 相关链接
  http://blog.itpub.net/7607759/viewspace-610951
  http://docs.oracle.com/cd/E11882_01/appdev.112/e40758/d_sched.htm#ARPLS72300
Oracle Scheduler Jobs
Repeat Interval参数
  FREQ 关键字用来指定间隔的时间周期,可选参数有:YEARLY(年), MONTHLY(月), WEEKLY(周), DAILY(日), HOURLY(时), MINUTELY(分), SECONDLY(秒)等单位。
  INTERVAL 关键字用来指定间隔的频繁,可指定的值的范围从1-999。
  BYHOUR  指定一天中的小时。可指定的值的范围从1-24。16,17,18就表示每天下午的4、5、6点。
  BYDAY 关键字用来指定每周的哪天运行。
  BYMONTHDAY 关键字用来指定每月中的哪一天。-1 表示每月最后一天。
  BYMONTH  关键字用来指定每年的月份。
  BYDATE 指定日期。0310就表示3月10日。
  例如:
  运行每星期五。(所有这三个例子是等价的。)

  •   FREQ=DAILY; BYDAY=FRI;
  •   FREQ=WEEKLY; BYDAY=FRI;
  •   FREQ=YEARLY; BYDAY=FRI;
  设置任务隔一周运行一次,并且仅在周5运行:

  •   FREQ=WEEKLY; INTERVAL=2; BYDAY=FRI;
  在每月的最后一天运行

  •   FREQ=MONTHLY; BYMONTHDAY=-1;
  三月十日开。(两个例子是等价的)

  •   FREQ=YEARLY; BYMONTH=MAR; BYMONTHDAY=10;
  •   FREQ=YEARLY; BYDATE=0310;
  设置任务每10隔天运行:

  •   REPEAT_INTERVAL => 'FREQ=DAILY; INTERVAL=10';
  设置任务在每天的下午4、5、6点时运行:

  •   REPEAT_INTERVAL => 'FREQ=DAILY; BYHOUR=16,17,18';
  设置任务在每月29日运行:

  •   REPEAT_INTERVAL => 'FREQ=MONTHLY; BYMONTHDAY=29';
  设置任务在每年的最后一个周5运行:

  •   REPEAT_INTERVAL => 'FREQ=YEARLY; BYDAY=-1FRI';
  设置任务每隔50个小时运行:

  •   REPEAT_INTERVAL => 'FREQ=HOURLY; INTERVAL=50';
  repeat_interval => 'FREQ=HOURLY; INTERVAL=2'
  每隔2小时运行一次job
  repeat_interval => 'FREQ=DAILY'
  每天运行一次job
  repeat_interval => 'FREQ=WEEKLY; BYDAY=MON,WED,FRI"
  每周的1,3,5运行job
  repeat_interval => 'FREQ=YEARLY; BYMONTH=MAR,JUN,SEP,DEC; BYMONTHDAY=30'
  每年的3,6,9,12月的30号运行job
  既然说到了repeat_interval,你可能要问:"有没有一种简便的方法来得出,或者说是评估出job的每次运行时间,以及下一次的运行时间呢?"dbms_scheduler包提供了一个过程evaluate_calendar_string,可以很方便地完成这个需求!
  https://www.cnblogs.com/lanzi/archive/2012/11/23/2784815.html



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-563894-1-1.html 上篇帖子: Oracle cpu 相关参数解释 下篇帖子: 20、oracle用户管理恢复
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表