Oracle job说明

初始化相关参数job_queue_processes 
  alter system set job_queue_processes=39 scope=spfile;//最大值不能超过1000 ;job_queue_interval = 10 //调度作业刷新频率秒为单位
  job_queue_process 表示oracle能够并发的job的数量,可以通过语句
  show parameter job_queue_process;
  来查看oracle中job_queue_process的值。当job_queue_process值为0时表示全部停止oracle的job,可以通过语句
  ALTER SYSTEM SET job_queue_processes = 10;
  来调整启动oracle的job。
  相关视图:
  dba_jobs
  all_jobs
  user_jobs
  dba_jobs_running 包含正在运行job相关信息
  -------------------------
  提交job语法:
  begin
  sys.dbms_job.submit(job => :job,
   what => 'P_CLEAR_PACKBAL;',
   next_date => to_date('04-08-2008 05:44:09', 'dd-mm-yyyy hh24:mi:ss'),
   interval => 'sysdate+ 1/360');
  commit;
  end;
  /
  -------------------------
  创建JOB
  variable jobno number;
  begin
  dbms_job.submit(:jobno, 'P_CRED_PLAN;',SYSDATE,'SYSDATE+1/2880',TRUE);
  commit;
  运行JOB
  SQL> begin
   dbms_job.run(:job1);
   end;
   /
  删除JOB
  SQL> begin
   dbms_job.remove(:job1);
   end;
   /
  DBA_JOBS
  ===========================================
  字段(列) 类型 描述
  JOB NUMBER 任务的唯一标示号
  LOG_USER VARCHAR2(30) 提交任务的用户
  PRIV_USER VARCHAR2(30) 赋予任务权限的用户
  SCHEMA_USER VARCHAR2(30) 对任务作语法分析的用户模式
  LAST_DATE DATE 最后一次成功运行任务的时间
  LAST_SEC VARCHAR2(8) 如HH24:MM:SS格式的last_date日期的小时,分钟和秒
  THIS_DATE DATE 正在运行任务的开始时间,如果没有运行任务则为null
  THIS_SEC VARCHAR2(8) 如HH24:MM:SS格式的this_date日期的小时,分钟和秒
  NEXT_DATE DATE 下一次定时运行任务的时间
  NEXT_SEC VARCHAR2(8) 如HH24:MM:SS格式的next_date日期的小时,分钟和秒
  TOTAL_TIME NUMBER 该任务运行所需要的总时间,单位为秒
  BROKEN VARCHAR2(1) 标志参数,Y标示任务中断,以后不会运行
  INTERVAL VARCHAR2(200) 用于计算下一运行时间的表达式
  FAILURES NUMBER 任务运行连续没有成功的次数
  WHAT VARCHAR2(2000) 执行任务的PL/SQL块
  CURRENT_SESSION_LABEL RAW MLSLABEL 该任务的信任Oracle会话符
  CLEARANCE_HI RAW MLSLABEL 该任务可信任的Oracle最大间隙
  CLEARANCE_LO RAW MLSLABEL 该任务可信任的Oracle最小间隙
  NLS_ENV VARCHAR2(2000) 任务运行的NLS会话设置
  MISC_ENV RAW(32) 任务运行的其他一些会话参数
  --------------------------
  描述 INTERVAL参数值
  每天午夜12点 'TRUNC(SYSDATE + 1)'
  每天早上8点30分 'TRUNC(SYSDATE + 1) + (8*60+30)/(24*60)'
  每星期二中午12点 'NEXT_DAY(TRUNC(SYSDATE ), ''TUESDAY'' ) + 12/24'
  每个月第一天的午夜12点 'TRUNC(LAST_DAY(SYSDATE ) + 1)'
  每个季度最后一天的晚上11点 'TRUNC(ADD_MONTHS(SYSDATE + 2/24, 3 ), 'Q' ) -1/24'
  每星期六和日早上6点10分 'TRUNC(LEAST(NEXT_DAY(SYSDATE, ''SATURDAY"), NEXT_DAY(SYSDATE, "SUNDAY"))) + (6×60+10)/(24×60)'
  --------------------------
  1:每分钟执行
  Interval => TRUNC(sysdate,'mi') + 1/ (24*60)
  2:每天定时执行
  例如:每天的凌晨1点执行
  Interval => TRUNC(sysdate) + 1 +1/ (24)
  3:每周定时执行
  例如:每周一凌晨1点执行
  Interval => TRUNC(next_day(sysdate,'星期一'))+1/24
  4:每月定时执行
  例如:每月1日凌晨1点执行
  Interval =>TRUNC(LAST_DAY(SYSDATE))+1+1/24
  5:每季度定时执行
  例如每季度的第一天凌晨1点执行
  Interval => TRUNC(ADD_MONTHS(SYSDATE,3),'Q') + 1/24
  6:每半年定时执行
  例如:每年7月1日和1月1日凌晨1点
  Interval => ADD_MONTHS(trunc(sysdate,'yyyy'),6)+1/24
  7:每年定时执行
  例如:每年1月1日凌晨1点执行
  Interval =>ADD_MONTHS(trunc(sysdate,'yyyy'),12)+1/24
实际应用:
Shlhdb中
--以下脚本运行方式 放文件在c盘根目录
--cmd
--sqlplus shlhdb/shlhdb
--@c:/pz_ztt.txt
create or replace procedure pro_pz_ztt
is
--v number;
begin
insert into pz_ztt
select tcm,to_char(sysdate,'yyyy')-1 nf,ztm,pic
from pz_ztt where nf=(select max(to_number(nf)) from pz_ztt) and nf!=(select to_char(
sysdate,'yyyy')-1 from dual);
commit;
end pro_pz_ztt;
/
variable job number;
begin
  sys.dbms_job.submit(job => :job,
  what => 'pro_pz_ztt;',
  next_date => sysdate,
  interval => 'ADD_MONTHS(trunc(sysdate,''yyyy''),12)+1/24');
  commit;
end;
/
begin
dbms_job.run(:job);
end;
/

 

 

设置Oracle job 按指定时间只执行一次:

SQL> variable job1 number;
SQL> begin
  2  dbms_job.submit(:job1,'myproc;',to_date('2011-01-20 16:42:00','yyyy-mm-dd hh24:mi:ss'),'null');
  3  commit;
  4  end;
  5  /

 

而且job执行完成后会自动删除该job(oracle 10g)。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值