oracle中的定时器job

Oracle定时器常用于按指定时间或间隔执行存储过程。本文介绍了如何创建和配置存储过程以及利用定时器进行调用。例如,当系统时间达到预设的starttime时,自动将数据库中state字段值从0改为1。

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

oracle定时器 常用于在指定的时间或者时间间隔内对存储过程的调用

第一步写好存储过程;

第二步写job,在job中调用存储过程名,和执行时间,除了下面例子中的写法还可以通过plsql工具配置,原理完全相同,可见链接 https://www.cnblogs.com/yx007/p/6519544.html

在网上随便找的一个例子

问:我用的是ORACLE数据库,表里三个字段,id,starttime,state. 

如何做在系统时间到达设置的starttime时,数据库自动修改state的值0改为1。

答:

1.create table test(id int,starttime date,state int);
2.create or replace procedure sp_update is
cursor cur is select * from test where state=0;
v_id int;
v_starttime date;
v_state int;
begin
open cur;
loop
fetch cur into v_id,v_starttime,v_state;
exit when cur%notfound;
update test set state=1 where starttime=sysdate;
commit;
end loop;
close cur;
end;
/
3.创建JOB
SQL> variable job1 number;
SQL>
SQL> begin
2 dbms_job.submit(:job1,sp_update;',sysdate,'sysdate+1/1440'); --每天1440分钟,即一分钟运行sp_update过程一次
3 end;
4 /

PL/SQL 过程已成功完成。

运行JOB
SQL> begin
2 dbms_job.run(:job1);
3 end;
4 /
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值