oracle 创建存储过程 在job 定时执行

一、创建存储过程。

CREATE OR REPLACE PROCEDURE UPD_PICKUP_WEIGHT IS 
BEGIN
	UPDATE HK_DELIVERCOST_DETAIL deltDetl SET deltDetl.PICKUP_WEIGHT = 
	(
		SELECT nvl(hkPictDetl.BALANCE_WEIGHT,0) FROM 
		(
			SELECT 
						pictDetl.MASTER_BILL_CODE MASTER_BILL_CODE,
						nvl(SUM(pictDetl.BALANCE_WEIGHT),0) BALANCE_WEIGHT 
			FROM HK_PICKUPCOST_DETAIL pictDetl GROUP BY MASTER_BILL_CODE
		) hkPictDetl WHERE deltDetl.MASTER_BILL_CODE=hkPictDetl.MASTER_BILL_CODE
	);

END;


二、创建job,设置每天晚上凌晨执行上面的存储过程。

declare  
jobPickupWeight number; 
BEGIN
	dbms_job.submit(jobPickupWeight,'UPD_PICKUP_WEIGHT;',to_date(sysdate,'yyyy-mm-dd hh24:mi:ss'),'TRUNC(SYSDATE + 1)');
	commit;  
END;

三、删除指定的job。

BEGIN 
	dbms_job.remove(81);
	commit ;
END;

四、查询jobs相关字段信息。

select job,last_date,last_sec,broken,failures,interval, what from dba_jobs

字段说明如下:

job: 指的是job的id号。比如上面的 81 
failures:job执行的时候失败次数,如果超过了15次,那么broken列将被标为Y,以后就不会运行该job了 
broken:默认为N,如果为Y,意味着不再执行该job!
 
interval:执行job的间隔时间。
 
what:该job的实际工作。

五、job的相关知识。

1、字段说明。

字段(列)                      类型                       描述
 
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)                    任务运行的其他一些会话参数

2、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)'
 
每月25号00:00执行: 'TRUNC(LAST_DAY(SYSDATE ) + 25)'
 
--------------------------
 
1:每分钟执行
 
Interval => TRUNC(sysdate,'mi') + 1/ (24*60)
 
或
 
Interval => sysdate+1/1440
 
 
 
2:每天定时执行
 
例如:每天的凌晨1点执行
 
Interval => TRUNC(sysdate) + 1 +1/ (24)
 
3:每周定时执行
 
例如:每周一凌晨1点执行
 
Interval => TRUNC(next_day(sysdate,'星期一'))+1/24
例如:每周一凌晨2点执行 Interval => TRUNC(next_day(sysdate,'星期一'))+2/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
备注:

相关视图 :dba_jobs ,all_jobs ,user_jobs , dba_jobs_running (包含正在运行job相关信息)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值