oracle创建定时任务

工作中需要定时去做一些任务,比如定时执行某个存储过程等操作。
下文举个很简单的栗子创建oracle定时任务。

– ①②步在sql窗口执行即可
– ①创建一张表
CREATE TABLE a(a DATE);
– ②创建一个自定义过程
CREATE OR REPLACE PROCEDURE TEST AS
BEGIN
INSERT INTO a VALUES(SYSDATE);
END;
– ③④步必须在命令窗口执行(都必须在同一命令窗口执行,不然的话会报一个错误ORA-01008:并非所有的变量都已绑定。这个错误的原因是,另外开一个命令窗口执行的话,找不到变量【VAR job1 NUMBER】 )
– ③创建JOB 设定1分钟执行一次该任务
VAR job1 NUMBER;
BEGIN
dbms_job.submit(:job1,’test;’,sysdate,’sysdate+1/1440’);
COMMIT;
END;
/
– ④运行JOB
BEGIN
dbms_job.run(:job1);
END;
/
创建任务到这里就结束了。
每过一分钟,就会在表A中添加一条数据。

– ⑤删除JOB
BEGIN
dbms_job.remove(:job1);
END;
/


第③步中设定任务执行频率为一分钟一次,为’sysdate+1/1440’
以下提供一些简单的interval参数设置例子:
描述 Interval参数值
每天运行一次 ‘SYSDATE + 1’
每小时运行一次 ‘SYSDATE + 1/24’
每1分钟运行一次 ‘SYSDATE + 1/(60*24)’
每1秒运行一次 ‘SYSDATE + 1/(60*24*60)’
每隔一星期运行一次 ‘SYSDATE + 7’

如果设定每30分钟运行一次的话,就先找到每1分钟运行一次的’SYSDATE + 1/(60*24)’,把+后面的数值乘以30即可.即’SYSDATE + 30/(60*24)’

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值