Oracle定时任务(2)-DBMS_JOB

本文详细介绍了Oracle中的DBMS_JOB包,用于管理定时任务。DBMS_JOB在Oracle 10g之后被dbms_scheduler取代,但仍然可用。文章讲解了DBMS_JOB的关键参数,如job、what、next_date和interval,以及如何设置任务执行时间、重试机制和相关后台进程。还讨论了任务调度的灵活性和可能遇到的时间“漂移”问题。
摘要由CSDN通过智能技术生成

Oracle 10g之前,可以使用dbms_job来管理定时任务。
10g之后,Oracle引入dbms_scheduler来替代先前的dbms_job,
在功能方面,它比dbms_job提供了更强大的功能和更灵活的机制/管理。

DBMS_JOB包
DBMS_JOB包中包含有许多过程和方法

名称 类型 描述
DBMS_JOB.ISUBMIT 过程

提交一个新任务,用户指定一个任务号
dbms_job.isubmit (
job       IN BINARY_INTEGER,
what      IN VARCHAR2,
next_date IN DATE,
interval  IN VARCHAR2 DEFAULT 'NULL',
no_parse  IN BOOLEAN DEFAULT FALSE);

*no_parse indicates whether to parse job PL/SQL at time of submission (FALSE) or execution (TRUE)
exec dbms_job.isubmit(100, 'begin MYPROC;end;', SYSDATE);

DBMS_JOB.SUBMIT 过程 提交一个新任务,系统指定一个任务号
dbms_job.submit(
JOB       OUT BINARY_INTEGER,
WHAT      IN  VARCHAR2,
NEXT_DATE IN  DATE           DEFAULT SYSDATE,
INTERVAL  IN  VARCHAR2       DEFAULT 'NULL',
NO_PARSE  IN  BOOLEAN        DEFAULT FALSE,
INSTANCE  IN  BINARY_INTEGER DEFAULT 0,
FORCE     IN  BOOLEAN        DEFAULT FALSE);
DBMS_JOB.REMOVE 过程 从队列中删除一个已经存在的任务
dbms_job.removejob IN BINARY_INTEGER);
DBMS_JOB.CHANGE 过程 更改用户设定的任务参数
dbms_job.change(
job       IN BINARY_INTEGER,
what      IN VARCHAR2,
next_date IN DATE,
interval  IN VARCHAR2,
instance  IN BINARY_INTEGER DEFAULT NULL,
force     IN BOOLEAN        DEFAULT FALSE);
exec dbms_job.change(100,NULL,NULL,'SYSDATE+3');
DBMS_JOB.WHAT 过程 更改PL/SQL任务定义
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值