中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

oracle中的job

發布時間:2020-05-31 17:30:47 來源:網絡 閱讀:827 作者:sugar黑黑 欄目:關系型數據庫

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

oracle中的job

有關interval參數的值

oracle中的job

dba_jobs_running  列出當前實例中所有正在運行的job

desc dba_jobs_running 

oracle中的job

有關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	

未完待續。。。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

镇远县| 天台县| 安吉县| 永清县| 阜南县| 清苑县| 阿巴嘎旗| 沙田区| 城市| 三台县| 新巴尔虎右旗| 子长县| 平潭县| 海晏县| 衡阳市| 固原市| 许昌市| 毕节市| 阿勒泰市| 来安县| 宁阳县| 韶关市| 临湘市| 五指山市| 台湾省| 克山县| 黔西| 宣威市| 晋宁县| 田林县| 本溪市| 巴彦淖尔市| 额尔古纳市| 新和县| 顺平县| 丹寨县| 长岭县| 衢州市| 舞钢市| 辉南县| 天长市|