一个简单例子:
创建测试表
SQL>; create table a(a date);
表已创建。
创建一个自定义过程
SQL>; create or replace procedure test as
2 begin
3 insert into a values(sysdate);
4 end;
5 /
过程已创建。
创建JOB
SQL>; variable job1 number;
SQL>;
SQL>; begin
2
dbms_job.submit(:job1,'test;',sysdate,'sysdate+1/1440'); --每天1440分钟,即一分钟运行test过程一次,注意test后面的分号“;”必须得写;
3 end;
4 /
PL/SQL 过程已成功完成。
运行JOB
SQL>; begin
2 dbms_job.run(:job1);
3 end;
4 /
PL/SQL 过程已成功完成。
SQL>; select to_char(a,'yyyy/mm/dd hh24:mi:ss') 时间 from a;
时间
-------------------
2001/01/07 23:51:21
2001/01/07 23:52:22
2001/01/07 23:53:24
删除JOB
SQL>; begin
2 dbms_job.remove(:job1);
3 end;
4 /
PL/SQL 过程已成功完成。
1 一个简单的JOB实列
1. 创建测试表
create table test_table(mydate date);
2. 创建一个自定义过程
create or replace procedure test_procedure as
begin
insert into test_table values(sysdate);
end;
3. 创建JOB
每天1440分钟,即一分钟运行存储过程一次
variable test_job number;
begin
dbms_job.submit(:test_job,'test_procedure;',sysdate,'sysdate+1/1440');
end;
4. 运行JOB
begin
dbms_job.run(:test_job);
end;
5. 查看JOB运行结果
select to_char(test_table,'yyyy-mm-dd hh24:mi:ss') from test_table;
6. 更改JOB的间隔时间
begin
dbms_job.interval(:test_job, 'sysdate+1);
end;
7. 删除job
begin
dbms_job.remove(:test_job);
end;
2 JOB interval的设置说明
由于oracle的时间是以天为单位的,所以下面的job表示每1天执行一次
dbms_job.submit(:test_job,'test_procedure;',sysdate,'sysdate+1’);
第四个参数说明:sysdate+1 表示每天执行一次
sysdate+1/24 表示每小时执行一次
sysdate+1/(24*60) 表示每分钟执行一次
sysdate+1/(24*60*60) 表示每秒执行一次
3 “并非所有变量都已关联”的解决办法
SQL> begin
2 dbms_job.interval(:job_clearexpiredata, 'sysdata+1');
3 end;
4 /
begin
dbms_job.interval(:job_clearexpiredata, 'sysdata+1');
end;
ORA-01008: 并非所有变量都已关联
如果出现上面的错误提示,解决方法如下
1. 找出JOB的ID号
SQL> select JOB from user_jobs;
JOB
----------
7
2. 根据ID号运行命令
begin
dbms_job.interval(7, 'sysdate+7');
end;
3. 提交
commit;
4 一些必要的参数
1. 修改initsid.ora参数
job_queue_processes = 4
job_queue_interval = 10
job_queue_keep_connections=true
2. 修改可执行作业个数为20个
3. 修改取消限制模式
4. 两个必要的表
5 相关的几个JOB操作
删除job: dbms_job.remove(jobno);
修改要执行的操作: job:dbms_job.what(jobno,what);
修改下次执行时间: dbms_job.next_date(job,next_date);
修改间隔时间: dbms_job.interval(job,interval);
停止job: dbms.broken(job,broken,nextdate);
启动job: dbms_job.run(jobno);