(9)使用Chains之創(chuàng)建CHAIN |
[君三思] 2009-9-4 |
五、使用Chains今天要來認(rèn)識一位新同學(xué):CHAIN(注意不要敲成CHINA)。CHAIN可以被視做一組Programs的復(fù)合,舉個簡單的例子:運(yùn)行PROGRAM:A以及PROGRAM:B,如果成功的話繼續(xù)運(yùn)行PROGRAM:C,否則的話運(yùn)行PROGRAM:D。Programs:A、B、C、D以及執(zhí)行的邏輯關(guān)系就構(gòu)成了一個最簡單的CHAIN。 關(guān)于CHAIN的管理操作比較多,比如創(chuàng)建/刪除/修改Chains,添加/修改/刪除Chain Steps等等。 5.1 創(chuàng)建Chains5.1.1 創(chuàng)建CHAIN對象創(chuàng)建CHAIN使用DBMS_SCHEDULER.CREATE_CHAIN過程,這個過程調(diào)用非常簡單,因?yàn)樾枰付ǖ膮?shù)極少,該過程的定義如下: SQL> desc dbms_scheduler.create_chain; Parameter Type Mode Default? ------------------- ---------------------- ---- -------- CHAIN_NAME VARCHAR2 IN RULE_SET_NAME VARCHAR2 IN Y EVALUATION_INTERVAL INTERVAL DAY TO SECOND IN Y COMMENTS VARCHAR2 IN Y在創(chuàng)建時,甚至可以簡單到只指定一個CHAIN的名稱,其它均為空即可,例如: SQL> exec dbms_scheduler.create_chain(¨my_chain1¨); PL/SQL procedure successfully completed.定義好的Chains,可以通過*_SCHEDULER_CHAINS視圖查看,例如: SQL> select chain_name from user_scheduler_chains; CHAIN_NAME ------------------------------ MY_CHAIN1注意,不是說創(chuàng)建了CHAIN就齊活,只有一個CHAIN對象ORACLE還是啥也干不了(當(dāng)然啦,相信從上面執(zhí)行的創(chuàng)建語句大家也看出來了),CHAIN對象創(chuàng)建之后,要做的工作其實(shí)才剛剛開始。其后,還需要定義Chain Steps以及Chain rules。 5.1.2 創(chuàng)建Chain StepChain Steps 就是用來指定CHAIN執(zhí)行的操作及執(zhí)行步驟,創(chuàng)建CHAIN STEP是通過DBMS_SCHEDULER.DEFINE_CHAIN_STEP過程進(jìn)行,例如,為剛剛創(chuàng)建的my_chain1添加一個step,執(zhí)行操作如下: SQL> begin 2 DBMS_SCHEDULER.DEFINE_CHAIN_STEP ( 3 chain_name => ¨my_chain1¨, 4 step_name => ¨my_step1¨, 5 program_name => ¨p_p1¨); 6 end; 7 / PL/SQL procedure successfully completed.Chain Steps 即可以調(diào)用PROGRAM(注意是program,不是procedure,當(dāng)然program中可以定義執(zhí)行procedure),也可以調(diào)用EVENT,甚至調(diào)用其它CHAIN(這就叫嵌套CHAIN)。 下面接著為my_chain1添加兩個step,操作如下: SQL> begin 2 DBMS_SCHEDULER.DEFINE_CHAIN_STEP ( 3 chain_name => ¨my_chain1¨, 4 step_name => ¨my_step2¨, 5 program_name => ¨p_p2¨); 6 DBMS_SCHEDULER.DEFINE_CHAIN_STEP ( 7 chain_name => ¨my_chain1¨, 8 step_name => ¨my_step3¨, 9 program_name => ¨p_p3¨); 10 end; 11 / PL/SQL procedure successfully completed.要查詢定義的Chain Steps,則是通過*_SCHEDULER_CHAIN_STEPS視圖,例如: SQL> select chain_name,step_name,program_name from user_scheduler_chain_steps; CHAIN_NAME STEP_NAME PROGRAM_NAME -------------------- -------------------- -------------------- MY_CHAIN1 MY_STEP1 P_P1 MY_CHAIN1 MY_STEP2 P_P2 MY_CHAIN1 MY_STEP3 P_P35.1.3 創(chuàng)建Chain Rule接下來,要為CHAIN的運(yùn)行定義規(guī)則。定義規(guī)則是使用DBMS_SCHEDULER.DEFINE_CHAIN_RULE過程,Chain Rules依賴于Chain Steps,每個CHAIN RULE都擁有condition和action屬性,當(dāng)滿足condition時則執(zhí)行action中指定的step。 DBMS_SCHEDULER.DEFINE_CHAIN_RULE 過程的語法如下: SQL> desc dbms_scheduler.define_chain_rule; Parameter Type Mode Default? ---------- -------- ---- -------- CHAIN_NAME VARCHAR2 IN CONDITION VARCHAR2 IN ACTION VARCHAR2 IN RULE_NAME VARCHAR2 IN Y COMMENTS VARCHAR2 IN YCHAIN_NAME 就不說了,需要注意的是CONDITION和ACTION兩個參數(shù)。在為condition參數(shù)指定值時,其語法看起來稍稍復(fù)雜一些,或者說是靈活,condition參數(shù)值支持下列的語法形式:
甚至于,還可以制定成下列邏輯語法:
比如說,我們希望條件為step1成功運(yùn)行,那么可以指定condition參數(shù)值如下:
Action 參數(shù)相對簡單一些,這個參數(shù)用來指定當(dāng)滿足condition參數(shù)時,CHAIN執(zhí)行的操作。 例如,創(chuàng)建CHAIN RULE,首先執(zhí)行my_step1,如果my_step1成功執(zhí)行的話,就繼續(xù)執(zhí)行my_step2,如果my_step2也成功執(zhí)行的話,則結(jié)束該CHAIN,創(chuàng)建腳本如下: SQL> BEGIN 2 DBMS_SCHEDULER.DEFINE_CHAIN_RULE ( 3 chain_name => ¨my_chain1¨, 4 condition => ¨TRUE¨, 5 action => ¨START my_step1¨, 6 rule_name => ¨my_rule1¨); 7 DBMS_SCHEDULER.DEFINE_CHAIN_RULE ( 8 chain_name => ¨my_chain1¨, 9 condition => ¨my_step1 completed¨, 10 action => ¨START my_step2¨, 11 rule_name => ¨my_rule2¨); 12 DBMS_SCHEDULER.DEFINE_CHAIN_RULE ( 13 chain_name => ¨my_chain1¨, 14 condition => ¨my_step2 completed¨, 15 action => ¨end 0¨, 16 rule_name => ¨my_rule3¨); 17 END; 18 / PL/SQL procedure successfully completed.5.1.4 運(yùn)行Chains最后,來運(yùn)行一下創(chuàng)建的my_chain1吧,手動運(yùn)行CHAIN是通過DBMS_SCHEDULER.RUN_CHAIN過程,例如: SQL> BEGIN 2 DBMS_SCHEDULER.RUN_CHAIN ( 3 chain_name => ¨my_chain1¨, 4 start_steps => ¨my_step1¨); 5 END; 6 / PL/SQL procedure successfully completed.語句執(zhí)行成功,下面需要查看一下執(zhí)行的結(jié)果。我們之前定義的p_p1等program對象,實(shí)際上是調(diào)用procedure,向一個指定表jss_t2中插入記錄,這里直接查詢一下該表,就知道執(zhí)行情況了(在此之前,jss_t2表為空): SQL> select * from jss_t2; TP DT ------------------------------ ------------ p_p1 inserted 03-SEP-09 p_p2 inserted 03-SEP-09你看,jss_t2表中有了兩條記錄,對應(yīng)前面設(shè)置的CHAIN RULE,說明my_step1和my_step2均已正確執(zhí)行。
手動執(zhí)行的CHAIN的話沒有系統(tǒng)級的日志記錄,因此如果希望看到詳細(xì)執(zhí)行情況的話,建議創(chuàng)建job來執(zhí)行CHAIN,例如: SQL> BEGIN 2 DBMS_SCHEDULER.CREATE_JOB ( 3 job_name => ¨chain_job_1¨, 4 job_type => ¨CHAIN¨, 5 job_action => ¨my_chain1¨, 6 repeat_interval => ¨freq=daily;interval=1¨, 7 enabled => TRUE); 8 END; 9 / PL/SQL procedure successfully completed.然后,dba就可以通過定期觀察*_scheduler_job_run_details視圖來確認(rèn)chain的執(zhí)行情況了。 |