Oracle的任务计划


有时候我们为了某个需求需要定期的去执行一个任务或操作,那么这时我们会想到任务计划。
没错,第一种方法我们可以利用系统的计划任务去执行某个程序。
如果我们是想在数据库中 定期的去处理数据,那么我们可以用数据库的计划任务。SQLserver2005 和Oracle 都有计划任务的功能。

下面是介绍Oracle9i的任务计划操作方法:
先看一个简单例子 :     
    
 1. 创建测试表   
     create   table   a(a   date);   


 2. 创建一个存储过程   
       create   or   replace   procedure   test   as   
         begin   
             insert   into   a   values(sysdate);   
         end;   
 3. 创建JOB(任务计划) 

    将以下语句在SQL*PLUS或PL/SQL的command Window中执行。

 
     variable   job1   number;   
       begin   
         dbms_job.submit(:job1,'test;',sysdate,'sysdate+1/1440');
    --每天1440分钟,即一分钟运行test存储过程一次     
      end;   
 4. 运行JOB   
   begin   
       dbms_job.run(:job1);   
    end;   
    
 
5. 查看执行结果    
  select   to_char(a,'yyyy/mm/dd   hh24:mi:ss')   时间   from   a;   
    
  时间   
  -------------------   
  2001/01/07   23:51:21   
  2001/01/07   23:52:22   
  2001/01/07   23:53:24   
    
  6.删除JOB   
      dbms_job.remove(:job1);   
   
    
  select   *   from   all_jobs;   -- 查看数据库系统所有任务 
    
    
 

job的使用说明:   
    
  DBMS_JOB.SUBMIT(:jobno,//job号   
                                  'your_procedure;',//要执行的过程   
                                  trunc(sysdate)+1/24,//下次执行时间   
                                  'trunc(sysdate)+1/24+1'//每次间隔时间   
                                );   
  删除job:dbms_job.remove(jobno);   
  修改要执行的操作:job:dbms_job.what(jobno,what);   
  修改下次执行时间:dbms_job.next_date(job,next_date);   
  修改间隔时间:dbms_job.interval(job,interval);   
  停止job:dbms.broken(job,broken,nextdate);   
  启动job:dbms_job.run(jobno);   
  例子:   
  VARIABLE   jobno   number;   
  begin   
              DBMS_JOB.SUBMIT(:jobno,     
                              'Procdemo;',//Procdemo为过程名称     
                                SYSDATE,   'SYSDATE   +   1/720');   
                    commit;   
  end;   
    
  执行Oracle JOB前提:


   修改job_queue_processes的值(保证其不为0否则JOB不自动运行)   


  可通过select   *   from   v$parameter;查看其值;   


  方法1:

  startup   pfile='C:/oracle/ora90/database/initorcl.ora';   
  需要修改initorcl.ora文件的job_queue_processes参数,然后重新启动数据库以后才能生效  

 
  方法2:
  alter   system   set   job_queue_processes=10     
  不需要重新启动数据库就能生效,系统自动修改init.ora文件

你可能感兴趣的:(数据库)