i漂泊

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 5112|回复: 0

Oracle的任务计划

[复制链接]
TA的礼物信息
  • 收到:0
  • 送出:2
发表于 2013-8-15 14:31:07 | 显示全部楼层 |阅读模式

有时候我们为了某个需求需要定期的去执行一个任务或操作,那么这时我们会想到任务计划。
没错,第一种方法我们可以利用系统的计划任务去执行某个程序。
如果我们是想在数据库中 定期的去处理数据,那么我们可以用数据库的计划任务。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文件


回复

使用道具 举报

高级模式
B Color Image Link Quote Code Smilies

本版积分规则

QQ|小黑屋|手机版|IPiaoBo Inc. ( 渝ICP备17002826号 )

GMT+8, 2024-3-29 21:13 , Processed in 0.066324 second(s), 47 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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