问题:假设有一个存储过程p_test,如何才能每20分钟执行一次?
更多内容请看Oracle 10g基础应用专题,或进入讨论组讨论。
解答:
1、把init.ora中如下两个参数打开
JOB_QUEUE_INTERVAL=60
JOB_QUEUE_PROCESSES=4
job_queue_keep_connections=true
然后重启一个库,如果原来已经打开了则不用这步了
2、示例,以下由sqlplus 来执行,具体参照一下相关的文档
VARIABLE jobno number;
BEGIN
DBMS_JOB.SUBMIT(:jobno,
’p_test;’
SYSDATE,’SYSDATE + 1/72’);
commit;
END;
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;’,
SYSDATE, ’SYSDATE + 1/720’);
commit;
end;
相关图文阅读
频道图文推荐
健 康 咨 询
时 尚 咨 询
相关专题
- Oracle 10g基础应用 (4671篇文章)
- 甲骨文:从手机功能变化看数据库性能扩展 (27次浏览)
- Windows环境中同时安装Oracle9i 10g和11g (25次浏览)
- 详细讲解Oracle表分区的相关概念及其优点 (16次浏览)
- Oracle 10G 新特性--透明数据加密技术 (15次浏览)
- Oracle数据库exp imp按用户导出导入实例 (12次浏览)
- Oracle中 in 和 not in的巨大区别 (12次浏览)
- Oracle:ERP伸向企业外部 (11次浏览)
- 教你快速掌握一个简单的Oracle定时任务 (9次浏览)
- 教你快速掌握Oracle数据库中的like优化 (9次浏览)
- Oracle ERP 11i 维护经验 (9次浏览)



