工作中需要定时去做一些任务,比如定时执行某个存储过程等操作。
下文举个很简单的栗子创建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)’