1. 程式人生 > >oracle 建立儲存過程 在job 定時執行

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相關資訊)