ORACLE JOB

遇到的问题: 
本机运行环境: oracle 10g + PL/SLQ 9.0 + win XP 

问题1: interval => 'sysdate+1/86400' 定时间隔为1秒时,job每5秒执行一次 
问题2: interval => 'sysdate+1/8640'  定时间隔为10秒时,job每15秒执行一次 



1、建立存储过程 

Sql代码   收藏代码
  1. create or replace procedure test as  
  2. begin  
  3.        insert into zz_test(name,age) values('11',sysdate);  
  4. end;  



2、创建job 

Sql代码   收藏代码
  1. --创建一个job,这个job在创建的时候已经被运行  
  2. variable test_job number;                 
  3. begin  
  4.   sys.dbms_job.submit(job => :test_job,           --对应的唯一id(jobId<->jobName)唯一映射  
  5.                       what => 'test;',            --调用的存储过程  
  6.                       next_date => sysdate,       --第一次执行时间  
  7.                       interval => 'sysdate+1/1440');--执行间隔  
  8.   commit;  
  9. end;  
  10. /  
  11.   
  12. --查看创建的JOB  
  13. select * from sys.user_jobs;  



3、执行job 

Sql代码   收藏代码
  1. begin  
  2.    dbms_job.run(:job);        --执行job  
  3. end;  
  4. /  



4、停止job 

Sql代码   收藏代码
  1. --停止JOB  
  2. begin  
  3.   sys.dbms_job.broken(48,true);  
  4. end;  
  5. /  



5、删除job 

Sql代码   收藏代码
  1. begin  
  2.   dbms_job.remove(:job1);     --删除job  
  3. end;  
  4. /  




备注: 

Sql代码   收藏代码
  1. 除了submit参数外,其余的几个参数有:    
  2.     
  3.         dbms_job.run(v_job);         --运行job    
  4.     
  5.         dbms_job.broken(v_job,true,next_date);        --停止一个job,里面参数true也可是false,next_date(某一时刻停止)也可是sysdate(立刻停止)。    
  6.     
  7.         dbms_job.remove(v_job);        --删除某个job    
  8.     
  9.         dbms_job.what(v_job,'sp_fact_charge_code;');        --修改某个job名    
  10.     
  11.         dbms_job.next_date(v_job,sysdate);        --修改下一次运行时间    



附件 测试JOB 

Sql代码   收藏代码
  1. --说明 :每日将eb_plogon_ctrl.failtoday、eb_pcust_limit.dayamt、eb_pcust_limit.extdayamt 清零  
  2.   
  3. --建立存储过程  
  4. create or replace procedure Day_limit_return_to_zero as    
  5. begin   
  6.   update eb_plogon_ctrl t set t.failtoday = 0;   
  7.   update eb_pcust_limit t set t.dayamt = 0, t.extdayamt =0 ;  
  8. end;  
  9.     
  10. --建立job  
  11. variable Day_limit_return_to_zero number;                 
  12. begin  
  13.   sys.dbms_job.submit(job => :Day_limit_return_to_zero,             
  14.                       what => 'Day_limit_return_to_zero;',  
  15.                       next_date => sysdate,  
  16.                       interval => 'TRUNC(sysdate)+1+1/86400');  
  17.   commit;  
  18. end;  
  19. /  
  20.   
  21. --查看创建的JOB,获得创建的job编号  
  22. select * from sys.user_jobs;  
  23.   
  24. --通过job的编号删除JOB,“54”为上一步查询出来的job的id  
  25. begin  
  26.   sys.dbms_job.remove(54);  
  27.   commit;  
  28. end;  
  29. /  
  30.       
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值