標籤:job 定時任務 oracle
oracle知識點-job
oracle中的job類似於Linux中的crontab的作用,用於定時執行某些操作
相關視圖:dba_jobs,user_jobs,all_jobs,dba_jobs_running
相關參數:job_queue_processes
相關包:dbms_job
有關dba_jobs、dba_jobs_running 欄位的解釋:
dba_jobs 描述資料庫中所有的job
desc dba_jobs
650) this.width=650;" src="http://s3.51cto.com/wyfs02/M02/70/97/wKioL1W52aSwu4fDAAUQCnC9OCs827.jpg" title="2015-07-30_154834.png" alt="wKioL1W52aSwu4fDAAUQCnC9OCs827.jpg" />
有關interval參數的值
650) this.width=650;" src="http://s3.51cto.com/wyfs02/M00/70/97/wKioL1W52djA1Y4SAAKnAwGEZUw005.jpg" title="2015-07-30_154858.png" alt="wKioL1W52djA1Y4SAAKnAwGEZUw005.jpg" />
dba_jobs_running 列出當前執行個體中所有正在啟動並執行job
desc dba_jobs_running
650) this.width=650;" src="http://s3.51cto.com/wyfs02/M01/70/9A/wKiom1W51_qjtjUYAAHqsLZekzU668.jpg" title="2015-07-30_154907.png" alt="wKiom1W51_qjtjUYAAHqsLZekzU668.jpg" />
有關job_queue_processes的解釋:
指定單個執行個體中執行dbms_job jobs and Oracle Scheduler (dbms_scheduler) jobs的最大數量。如果job_queue_processes設定為0,dbms_job jobs和Oracle Scheduler不會在執行個體上運行。取值範圍是0-1000。
有關dbms_job包的解釋:
dbms_job包含的子過程有broken(),change(),instance(),interval(),isubmit(),next_date(),remove(),run(),submit(),user_export(),what()
1.broken()過程更新一個已提交的工作的狀態,用來把一個已破工作標記為未破工作
PROCEDURE BROKEN Argument NameTypeIn/Out Default? ------------------------------ ----------------------- ------ -------- JOBBINARY_INTEGERIN BROKEN BOOLEAN IN NEXT_DATEDATEIN DEFAULT
job參數是工作號,它在問題中唯一標識工作。
broken參數指示此工作是否將標記為破——TRUE說明此工作將標記為破,FLASE說明該工作將標記為未破。
next_date參數指示在什麼時候此工作將再次運行。此參數預設值為當前日期和時間。
job如果由於某種原因未能成功之行,oracle將重試16次後,還未能成功執行,將被標記為broken重新啟動狀態為broken的job
2.change()過程用來改變指定工作的設定
PROCEDURE CHANGE Argument NameTypeIn/Out Default? ------------------------------ ----------------------- ------ -------- JOBBINARY_INTEGERIN WHATVARCHAR2IN NEXT_DATEDATEIN INTERVALVARCHAR2IN INSTANCEBINARY_INTEGERIN DEFAULT FORCEBOOLEAN IN DEFAULT
job參數是一個整數值,它唯一標識此工作。
What參數是由此工作啟動並執行一塊PL/SQL代碼塊。
next_date參數指示什麼時候該工作將被執行。
interval參數指示一個工作重執行的頻度。
3.instance()過程
PROCEDURE INSTANCE Argument NameTypeIn/Out Default? ------------------------------ ----------------------- ------ -------- JOBBINARY_INTEGERIN INSTANCEBINARY_INTEGERIN FORCEBOOLEAN IN DEFAULT
4.interval()過程用來顯式地設定重新執行一個工作之間的時間間隔數
PROCEDURE INTERVAL Argument NameTypeIn/Out Default? ------------------------------ ----------------------- ------ -------- JOBBINARY_INTEGERIN INTERVALVARCHAR2IN
interval參數指示一個工作重執行的頻度
5.isubmit()過程用來用特定的工作號提交一個工作
PROCEDURE ISUBMIT Argument NameTypeIn/Out Default? ------------------------------ ----------------------- ------ -------- JOBBINARY_INTEGERIN WHATVARCHAR2IN NEXT_DATEDATEIN INTERVALVARCHAR2IN DEFAULT NO_PARSEBOOLEAN IN DEFAULT
這個過程和submit()過程的唯一區別在於此job參數作為IN型參數傳遞且包括一個由開發人員提供的工作號。如果提供的工作號已被使用,將產生一個錯誤
6.next_date()過程用來顯式地設定一個工作的執行時間
FUNCTION IS_JOBQ RETURNS BOOLEANPROCEDURE NEXT_DATE Argument NameTypeIn/Out Default? ------------------------------ ----------------------- ------ -------- JOBBINARY_INTEGERIN NEXT_DATEDATEIN
next_date參數指示了此工作應被執行的日期與時間
7.remove()過程用來刪除一個已計劃啟動並執行工作
PROCEDURE REMOVE Argument NameTypeIn/Out Default? ------------------------------ ----------------------- ------ -------- JOBBINARY_INTEGERIN
這個參數的值是由為此工作調用submit()過程返回的job參數的值。已正在啟動並執行工作不能由調用過程式刪除。
8.run()過程用來立即執行一個指定的工作
PROCEDURE RUN Argument NameTypeIn/Out Default? ------------------------------ ----------------------- ------ -------- JOBBINARY_INTEGERIN FORCEBOOLEAN IN DEFAULT
9.submit()過程 工作被正常地計劃好
PROCEDURE SUBMIT Argument NameTypeIn/Out Default? ------------------------------ ----------------------- ------ -------- JOBBINARY_INTEGEROUT WHATVARCHAR2IN NEXT_DATEDATEIN DEFAULT INTERVALVARCHAR2IN DEFAULT NO_PARSEBOOLEAN IN DEFAULT INSTANCEBINARY_INTEGERIN DEFAULT FORCEBOOLEAN IN DEFAULT
job參數是由submit()過程返回的binary_ineger。這個值用來唯一標識一個工作。
what參數是將被執行的PL/SQL代碼塊。
next_date參數指識何時將運行這個工作。
interval參數何時這個工作將被重新執行。
no_parse參數指示此工作在提交時或執行時是否應進行文法分析——TRUE指示此 PL/SQL代碼在它第一次執行時應進行文法分析,而FALSE指示本PL/SQL代碼應立即進行文法分析。
10.user_export()過程返回一個命令,此命令用來安排一個存在的工作以便此工作能重新提交
PROCEDURE USER_EXPORT Argument NameTypeIn/Out Default? ------------------------------ ----------------------- ------ -------- JOBBINARY_INTEGERIN MYCALL VARCHAR2IN/OUT
my_call參數包含在它的目前狀態重新提交此工作所需要的本文
11.user_export()過程
PROCEDURE USER_EXPORT Argument NameTypeIn/Out Default? ------------------------------ ----------------------- ------ -------- JOBBINARY_INTEGERIN MYCALL VARCHAR2IN/OUT MYINST VARCHAR2IN/OUT
12.what()過程
PROCEDURE WHAT Argument NameTypeIn/Out Default? ------------------------------ ----------------------- ------ -------- JOBBINARY_INTEGERIN WHATVARCHAR2IN
what參數指示將被執行的新的PL/SQL代碼。
查看目前使用者下的job資訊
SQL> show userUSER is "HR"SQL> SELECT SID, TYPE, ID1, ID2 FROM V$LOCK WHERE TYPE = ‘JQ‘;(查看job中鎖相關資訊)no rows selectedSQL> select job,what,failures,broken from user_jobs ;(查看目前使用者job資訊)no rows selectedSQL> select sid, r.job, log_user, r.this_date, r.this_sec from dba_jobs_running r, dba_jobs j where r.job = j.job ; (查看目前使用者正在啟動並執行job資訊) no rows selectedSQL> alter system set job_queue_processes = 20 ; (設定job隊列的數量)System altered.SQL> show parameter job_queue_processesNAME TYPE VALUE------------------------------------ ----------- ------------------------------job_queue_processes integer 20
job建立和測試
SQL> create table test_job (x date);Table created.SQL> create or replace procedure p_insert_to_test_job 2 as 3 begin 4 insert into test_job values (sysdate) ; 5 end ; 6 /Procedure created.SQL> variable job_num number ;SQL> begin 2 dbms_job.submit(:job_num,‘p_insert_to_test_job;‘,sysdate,‘sysdate+1/(24*60)‘); 3 commit ; 4 end ; 5 /PL/SQL procedure successfully completed.SQL> select * from test_job ;X-------------------2015-07-27 14:41:17SQL> select job,to_char(last_date,‘yyyy-mm-dd hh24:mi:ss‘) last_date,to_char(next_date,‘yyyy-mm-dd hh24:mi:ss‘) next_date,interval,what from user_jobs ; JOB LAST_DATE NEXT_DATE INTERVAL WHAT----- -------------------- -------------------- ----------------- ---------------- 3 2015-07-27 14:47:17 2015-07-27 14:48:17 sysdate+1/(24*60) p_insert_to_test_job; SQL> select job,what,failures,broken from user_jobs ; JOB WHAT FAILURES B---------- ----------------------- ---------- - 3 p_insert_to_test_job; 0 N SQL> execute dbms_job.remove(3); (刪除job)PL/SQL procedure successfully completed.SQL> select job,what,failures,broken from user_jobs ;no rows selected SQL> select job,to_char(last_date,‘yyyy-mm-dd hh24:mi:ss‘) last_date,to_char(next_date,‘yyyy-mm-dd hh24:mi:ss‘) next_date,interval,what from user_jobs ;no rows selectedSQL> select count(*) from test_job ; COUNT(*)----------13SQL> begin (重新運行)dbms_job.submit(:job_num,‘p_insert_to_test_job;‘,sysdate,‘sysdate+1/(24*60)‘);commit ;end ;/ 2 3 4 5 PL/SQL procedure successfully completed.SQL> select count(*) from test_job ; COUNT(*)----------15SQL> select job,what,failures,broken from user_jobs ; JOB WHAT FAILURES B---------- ----------------------- ---------- - 4 p_insert_to_test_job; 0 N
未完待續。。。
本文出自 “相守姑娘說” 部落格,請務必保留此出處http://sugarlovecxq.blog.51cto.com/6707742/1680152
oracle中的job