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文件

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要查看Oracle数据库的计划任务执行计划和执行情况,可以按照以下步骤进行操作: 1. 调整计划窗口: 1.1 查询窗口定义,可以使用命令`SELECT * FROM DBA_SCHEDULER_WINDOWS;`来查看当前的计划窗口定义。 2. 创建调度器(scheduler)和任务(job): 2.1 使用命令`DBMS_SCHEDULER.CREATE_SCHEDULE`创建一个调度器,指定计划任务的名称、执行间隔等参数。例如: ``` BEGIN DBMS_SCHEDULER.CREATE_SCHEDULE ( schedule_name => 'zbb_schedule', repeat_interval => 'FREQ=MINUTELY; INTERVAL=5', comments => 'Every 5 MINUTES'); END; ``` 2.2 添加任务到调度器,可以使用命令`DBMS_SCHEDULER.CREATE_JOB`来创建一个任务,并将其添加到调度器中。 3. 查看任务执行情况: 3.1 使用命令`SELECT * FROM USER_JOBS;`可以查看当前用户的调度任务。 3.2 使用命令`SELECT * FROM DBA_JOBS_RUNNING;`可以查看正在执行的调度任务。 3.3 使用命令`SELECT * FROM DBA_JOBS;`可以查看已执行完的调度任务。 3.4 使用命令`SELECT * FROM ALL_JOBS;`可以查看数据库系统中所有任务的信息。 通过以上步骤,你可以查看Oracle数据库的计划任务执行计划和执行情况。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Oracle计划窗口和自动任务汇总](https://blog.csdn.net/qq_28721869/article/details/118524869)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Oracle计划任务](https://blog.csdn.net/clq9761/article/details/84374905)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值