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;
select * from v$parameter where name='job_queue_processes';
来查看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相关信息
相关查证jobs情况的sql:
select job,last_date,last_sec,next_date,next_sec,interval,what from dba_jobs order by job;
-------------------------
提交job语法:
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
begin
dbms_job.submit(:jobno, 'p_cred_plan;',sysdate,'sysdate+1/2880',true);
commit;
运行job
dbms_job.run(:job1);
end;
/
删除job
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