为Oracle增加计划任务

经常在SQL Server上创建作业去定时执行某些任务,在Oracle下则一般都是通过编码的方式,通过项目自带的计划任务框架去调用存储过程。今天才发现,原来Oracle下创建一个计划任务要比SQL Server简单的多。

 

 

   1、创建计划任务:

       

Sql代码 复制代码
  1. X NUMBER;   
  2. GIN   
  3. SYS.DBMS_JOB.SUBMIT(job       => X,   
  4.                     what      => 'PROC_YKTSJTB;',--存储过程名称   
  5.                     next_date => trunc(sysdate+5/1440,'MI'),--下次执行时间   
  6.                     interval  => 'trunc(sysdate+1440/1440,''MI'')',--间隔时间   
  7.                     no_parse  => FALSE);   
  8. SYS.DBMS_OUTPUT.PUT_LINE('Job Number is: ' || to_char(x));   
  9. COMMIT;   
  10. D;  
  X NUMBER;
BEGIN
  SYS.DBMS_JOB.SUBMIT(job       => X,
                      what      => 'PROC_YKTSJTB;',--存储过程名称
                      next_date => trunc(sysdate+5/1440,'MI'),--下次执行时间
                      interval  => 'trunc(sysdate+1440/1440,''MI'')',--间隔时间
                      no_parse  => FALSE);
  SYS.DBMS_OUTPUT.PUT_LINE('Job Number is: ' || to_char(x));
  COMMIT;
END;

  

    以上主要注意三个参数:

     what  :需要计划任务执行的动作;

     next_date:下次计划任务执行的时间,具体时间可以根据oracle的trunc构造;

     interval:计划任务的执行周期;

 

     2、计划任务执行情况监控

        

Sql代码 复制代码
  1. select * from user_jobs;--查看调度任务   
  2.   
  3. select * from dba_jobs_running;--查看正在执行的调度任务   
  4.   
  5. select * from dba_jobs;--查看执行完的调度任务  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值