ORACLE中JOB的应用

 

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);
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值