oracle 建立儲存過程 在job 定時執行
阿新 • • 發佈:2019-01-29
一、建立儲存過程。
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相關資訊)