oracle中的job

來源:互聯網
上載者:User

標籤: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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.