Oracle Job调度

Oracle数据库中的JOB调度主要通过dbms_job包实现,包括isubmit、submit、remove、change等过程,用于提交、修改和管理作业。job的间隔时间由interval参数设定,如每天、每周等。此外,可以通过broken标志控制作业执行,run过程可手动启动作业,user_export过程用于作业的导出和重建。作业信息存储在dba_jobs、all_jobs、user_jobs表中。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下面几个表存储了数据库中 JOB 的一些信息:

select * from dba_jobs t;--作为dba用户可以查看的job
select * from dba_jobs_running t;--正在运行的job
select * from all_jobs t;--所有job
select * from user_jobs t;--当前用户job

oracle job操作主要是通过dbms_job包来实现的,该包主要有以下几个过程和函数:

这里写图片描述

其中,各个过程的功能如下:

isubmit

PROCEDURE isubmit    ( job       IN  BINARY_INTEGER,
                       what      IN  VARCHAR2,
                       next_date IN  DATE,
                       interval  IN  VARCHAR2 DEFAULT 'null',
                       no_parse  IN  BOOLEAN DEFAULT FALSE);

作用:用来用特定的工作号提交一个工作。各个参数的含义是:
job是job的工作号,由用户指定。

what:是要执行的pl/sql语句块。例如:
– ‘myproc( ”10-JAN-82”, next_date, broken);’
– ‘scott.emppackage.give_raise( ”JENKINS”, 30000.00);’
– ‘dbms_job.remove( job);’

interval:是一个日期函数, 必须是将来的某个时间,例如:
– ‘sysdate + 7’ – 每周一次
– ‘NEXT_DAY(sysdate,”TUESDAY”)’ – 每个星期二执行一次
– ‘null’ – 只执行一次
interval中的1代表1天,因此7天就是+7,每分钟执行1次就是sysdate+1/(24*60);

no_parse:默认是false。如果no_parse是false,oracle立即解析job相关的存储过程。如果设置为true,oracle会在第一次执行job的时候才去解析相关的存储过程。例如:如果你想提交一个job,但是其中有个表格还没有建好,那么可以把no_parse设置为true。

  这个过程与Submit()过程的唯一区别在于这里的工作号是传入的参数,而submit过程会自动计算工作号。如果isubmit过程传入的工作号已经存在,就会报错。

submit

提交一个job。

PROCEDURE isubmit    ( job       IN  BINARY_INTEGER,
                         what      IN  VARCHAR2,
                         next_date IN  DATE,
                         interval  IN  VARCHAR2 DEFAULT 'null',
                         no_parse  IN  BOOLEAN DEFAULT FALSE);

job:工作号,是一个传出参数,由过程自动计算。
其他参数和 isubmit 过程一样。
其中instance代表job运行在哪个实例上(集群)。默认0代表可以运行在任何实例上,有oracle调度机制确定。如果force是true,那么可以指定正整数的实例编号,如果force是false,那么指定的实例必须正在运行,否则会抛出异常(这一段还需要再查查。。。)。

remove

移除一个job。

PROCEDURE remove    ( job       IN  BINARY_INTEGER );

传入一个工作号。工作号可以从dba_jobs,all_jobs,user_jobs表中获取到。

change

修改job的设置。

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

job:工作号;
what,next_date,interval:和isubmit一样。如果是空,传入null即可。
instance和force字段的含义和submit过程一样。

what

修改一个已存在的job的what字段。也就是改变job的工作内容。

PROCEDURE what      ( job IN  BINARY_INTEGER, what  IN  VARCHAR2 );

next_date

修改一个已存在的job的next_date,即下次运行时间。

PROCEDURE next_date ( job IN  BINARY_INTEGER, next_date IN  DATE );

instance

修改一个已存在的job的运行实例。force字段和submit方法一样。

PROCEDURE instance ( job        IN BINARY_INTEGER,
                     instance   IN BINARY_INTEGER,
                     force      IN BOOLEAN DEFAULT FALSE);

interval

修改一个已存在的job的interval属性,也就是间隔时间。

PROCEDURE interval  ( job       IN  BINARY_INTEGER,
                      interval  IN  VARCHAR2 );

broken

设置broken标记,被标记为broken(即broken字段为true)的job永远不会执行。如果要让标记为broken的job运行,可以调用run过程或者重新调用broken过程将broken字段设为false。

PROCEDURE broken    ( job       IN  BINARY_INTEGER,
                      broken    IN  BOOLEAN,
                      next_date IN  DATE DEFAULT SYSDATE );

注意:默认的next_date是sysdate,表示立即生效。如果希望指定生效时间,需要设置这个字段。

run

运行指定的job。(job在submit后会自动运行,如果手动停止了job的运行,可以调用这个过程手动启动job。即使这个job是broken标记,也可以运行)。

PROCEDURE run       ( job       IN  BINARY_INTEGER,
                      force     IN  BOOLEAN DEFAULT FALSE);

执行这个过程会重新计算下次运行时间。从表:user_jobs中可以看到执行信息。

user_export

该过程有2个重载形式:

这里写图片描述

上面的过程的功能是根据传入的mycall重新创建job。
下面的过程的功能是修改关联的实例并且维持兼容性(?需要再查下资料)。

两个函数的功能如下:

background_process

返回一个布尔值,表示是前台进程还是后台进程。

is_jobq

暂时没有找到准确的定义。需要再查下资料。

实例

每隔30秒定时向表格中插入数据
(1)创建表格test:

create table test(
id number not null
);

(2)创建存储过程myproc:

create or replace procedure myproc is 
begin
       insert into test values (1);
 end myproc;

(3)提交job:

declare jobid number; 
begin 
dbms_job.submit(jobid,'myproc;',sysdate,'sysdate+1/2880'); 
commit; 
end; 

提交完成后会自动运行。可以查询user_jobs表获取jobid,然后调用broken过程停止job,或者调用remove过程移除job。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值