频道直达 - 专题 - 新闻 - 技巧 - 组网 - 开发 - 安全 - web编程 - 图像 - 操作系统 - 数据库 - 教育 - 旅游 - 健康 - 时尚 - 驱动 - 软件 - 游戏 - 多媒体 - ERP - 讨论组

Oralce数据库定时执行存储过程的设置

来源:pcdog 作者:佚名 出处:巧巧读书 2008-02-01 进入讨论组

  具体功能:

  每隔1分钟自动向"getSysDate表"中插入当前的系统时间。

  1、创测试表

  create table getSysDate(test date);

  2、创要定时执行的存储过程

create or replace procedure insertSysDate as 
begin 
insert into getSysDate values (sysdate);
end ;

  3、创建JOB,即创建待执行的定时任务过程

variable job1 number;
begin
dbms_job.submit(:job1,'insertSysdate;',sysdate,'sysdate+1/1440');
end;

  4、启动JOB,即启动并运行定时任务过程

  begin

  dbms_job.run(:job1);

  end;

  5、查看运行效果

  select to_char(test,'yyyy/mm/dd hh24:mi:ss') from getSysDate;

  结果:

2007/08/03 10:53:11
2007/08/03 11:05:51

<B>一部分重点参数的补充说明:</B>

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);

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

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

  或者直接用show parameter job_queue_processes;查看如下:

NAME TYPE VALUE
--------------------- ----------- 
job_queue_processes integer 10

  方法1:startup pfile='C:oracleora90databaseinitorcl.ora';

  //这个方法修改initorcl.ora文件的job_queue_processes参数,然后重新启动数据库

  方法2:alter system set job_queue_processes=10

  //这个方法不要重新启动数据库即可以生效,而系统自动修改init.ora文件以后才能生效。

   巧巧读书:http://www.qqread.com/oracle/2008/02/b395291.html

更多文章 更多内容请看存储过程数据库专栏数据库处理专题专题,或进入讨论组讨论。
更多专题 【深 度 阅 读】 相 关 文 章
    收藏此文】【 】【打印】【关闭
    相关图文阅读
    频道图文推荐
    健 康 咨 询
    时 尚 咨 询
    巧巧读书宗旨
    相关专题
    讨论组问题推荐
    站内各频道最新更新文档
    站内最新制作专题
    热门关键字导读
    Photoshop教 程照片处理 照片制作 PS快捷键 抠图
    计 算 机 故 障XP系统修复
    艺 术 与 设 计设计 流媒体 设计欣赏 边框
    计 算 机 安 全ARP
    站内频道文章精选
    巧巧电脑频道编辑信箱  告诉我们您想看的专题或文章