您好,登錄后才能下訂單哦!
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
有關interval參數的值
dba_jobs_running 列出當前實例中所有正在運行的job
desc dba_jobs_running
有關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 Name Type In/Out Default? ------------------------------ ----------------------- ------ -------- JOB BINARY_INTEGER IN BROKEN BOOLEAN IN NEXT_DATE DATE IN DEFAULT
job參數是工作號,它在問題中唯一標識工作。
broken參數指示此工作是否將標記為破——TRUE說明此工作將標記為破,FLASE說明該工作將標記為未破。
next_date參數指示在什么時候此工作將再次運行。此參數缺省值為當前日期和時間。
job如果由于某種原因未能成功之行,oracle將重試16次后,還未能成功執行,將被標記為broken重新啟動狀態為broken的job
2.change()過程用來改變指定工作的設置
PROCEDURE CHANGE Argument Name Type In/Out Default? ------------------------------ ----------------------- ------ -------- JOB BINARY_INTEGER IN WHAT VARCHAR2 IN NEXT_DATE DATE IN INTERVAL VARCHAR2 IN INSTANCE BINARY_INTEGER IN DEFAULT FORCE BOOLEAN IN DEFAULT
job參數是一個整數值,它唯一標識此工作。
What參數是由此工作運行的一塊PL/SQL代碼塊。
next_date參數指示什么時候該工作將被執行。
interval參數指示一個工作重執行的頻度。
3.instance()過程
PROCEDURE INSTANCE Argument Name Type In/Out Default? ------------------------------ ----------------------- ------ -------- JOB BINARY_INTEGER IN INSTANCE BINARY_INTEGER IN FORCE BOOLEAN IN DEFAULT
4.interval()過程用來顯式地設置重新執行一個工作之間的時間間隔數
PROCEDURE INTERVAL Argument Name Type In/Out Default? ------------------------------ ----------------------- ------ -------- JOB BINARY_INTEGER IN INTERVAL VARCHAR2 IN
interval參數指示一個工作重執行的頻度
5.isubmit()過程用來用特定的工作號提交一個工作
PROCEDURE ISUBMIT Argument Name Type In/Out Default? ------------------------------ ----------------------- ------ -------- JOB BINARY_INTEGER IN WHAT VARCHAR2 IN NEXT_DATE DATE IN INTERVAL VARCHAR2 IN DEFAULT NO_PARSE BOOLEAN IN DEFAULT
這個過程和submit()過程的唯一區別在于此job參數作為IN型參數傳遞且包括一個由開發者提供的工作號。如果提供的工作號已被使用,將產生一個錯誤
6.next_date()過程用來顯式地設定一個工作的執行時間
FUNCTION IS_JOBQ RETURNS BOOLEAN PROCEDURE NEXT_DATE Argument Name Type In/Out Default? ------------------------------ ----------------------- ------ -------- JOB BINARY_INTEGER IN NEXT_DATE DATE IN
next_date參數指示了此工作應被執行的日期與時間
7.remove()過程用來刪除一個已計劃運行的工作
PROCEDURE REMOVE Argument Name Type In/Out Default? ------------------------------ ----------------------- ------ -------- JOB BINARY_INTEGER IN
這個參數的值是由為此工作調用submit()過程返回的job參數的值。已正在運行的工作不能由調用過程序刪除。
8.run()過程用來立即執行一個指定的工作
PROCEDURE RUN Argument Name Type In/Out Default? ------------------------------ ----------------------- ------ -------- JOB BINARY_INTEGER IN FORCE BOOLEAN IN DEFAULT
9.submit()過程 工作被正常地計劃好
PROCEDURE SUBMIT Argument Name Type In/Out Default? ------------------------------ ----------------------- ------ -------- JOB BINARY_INTEGER OUT WHAT VARCHAR2 IN NEXT_DATE DATE IN DEFAULT INTERVAL VARCHAR2 IN DEFAULT NO_PARSE BOOLEAN IN DEFAULT INSTANCE BINARY_INTEGER IN DEFAULT FORCE BOOLEAN 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 Name Type In/Out Default? ------------------------------ ----------------------- ------ -------- JOB BINARY_INTEGER IN MYCALL VARCHAR2 IN/OUT
my_call參數包含在它的當前狀態重新提交此工作所需要的正文
11.user_export()過程
PROCEDURE USER_EXPORT Argument Name Type In/Out Default? ------------------------------ ----------------------- ------ -------- JOB BINARY_INTEGER IN MYCALL VARCHAR2 IN/OUT MYINST VARCHAR2 IN/OUT
12.what()過程
PROCEDURE WHAT Argument Name Type In/Out Default? ------------------------------ ----------------------- ------ -------- JOB BINARY_INTEGER IN WHAT VARCHAR2 IN
what參數指示將被執行的新的PL/SQL代碼。
查看當前用戶下的job信息
SQL> show user USER is "HR" SQL> SELECT SID, TYPE, ID1, ID2 FROM V$LOCK WHERE TYPE = 'JQ';(查看job中鎖相關信息) no rows selected SQL> select job,what,failures,broken from user_jobs ;(查看當前用戶job信息) no rows selected SQL> 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 selected SQL> alter system set job_queue_processes = 20 ; (設置job隊列的數量) System altered. SQL> show parameter job_queue_processes NAME 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:17 SQL> select job,to_char(last_date,'yyyy-mm-dd hh34:mi:ss') last_date,to_char(next_date,'yyyy-mm-dd hh34: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 hh34:mi:ss') last_date,to_char(next_date,'yyyy-mm-dd hh34:mi:ss') next_date,interval,what from user_jobs ; no rows selected SQL> select count(*) from test_job ; COUNT(*) ---------- 13 SQL> 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(*) ---------- 15 SQL> select job,what,failures,broken from user_jobs ; JOB WHAT FAILURES B ---------- ----------------------- ---------- - 4 p_insert_to_test_job; 0 N
未完待續。。。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。