Job Chains
建立chain的順序
- 建立chain object;
- 定義chain中的steps;
- 增加規則;
- 啟用chain;
- 建立指向這個chain的job。
建立Chain Object
實驗描述:
ENV:create table test_chain(id number);
createtable test_chain1(id number);
createtable test_chain2(id number);
step1:test_chain1表插入一條資料;
step2:step1執行成功後,test_chain中有超過兩條資料時,插入test_chain2表一條資料。
begin
dbms_scheduler.create_chain(chain_name=>'my_chain1',rule_set_name=>null,evaluation_interval=>interval '1' minute,
comments=>'Chain with 30 minuteevaluation interval');
end;
/
PL/SQL procedure successfully completed.
evaluation_interval指的是chain rule的掃描間隔,這裡是自定義的。Scheduler在啟動job chain時和每次執行完chain step時都會去掃描chain rule,這裡除了啟動job chain時和chain step結束時,還會每一分鐘自動掃描一次來判斷rule的正确性。這個參數對于某種特殊情形,本次實驗就啟用這個參數。
定義Chain Steps
建立program
dbms_scheduler.create_program(program_name=>'my_program1',program_type=>'PLSQL_BLOCK',
program_action=>'begin insert intotest_chain1 values (1);commit;end;');
dbms_scheduler.create_program(program_name=>'my_program2',program_type=>'PLSQL_BLOCK',
program_action=>'begin insert intotest_chain2 values (2);commit;end;');
--enable program
SQL> begin
2 dbms_scheduler.enable('my_program1,my_program2');
3 end;
4 /
建立step
dbms_scheduler.define_chain_step(chain_name=>'my_chain1',step_name=>'my_step1',program_name=>'my_program1');
dbms_scheduler.define_chain_step(chain_name=>'my_chain1',step_name=>'my_step2',program_name=>'my_program2');
Note:定義step時,program和chain可以不存在,但是啟動chain時,必須保證program
和chain存在。
增加Chain規則
Rule描述:
step1直接執行;
step2執行條件:step1執行成功,并且(selectcount(*) from test_chain) >=2
begin
dbms_scheduler.define_chain_rule(chain_name=>'my_chain1',condition=>'TRUE',action=>'startmy_step1',rule_name=>'rule_1');
dbms_scheduler.define_chain_rule(chain_name=>'my_chain1',condition=>':my_step1.state=''SUCCEEDED''and (select count(*) from test_chain) >=2',
action=>'startmy_step2',rule_name=>'rule_1_2');
啟用Chain
dbms_scheduler.enable('my_chain1');
建立Chain job
Note:直接調用run_chain運作則不需enablechain,建立job則需要。
dbms_scheduler.create_job(job_name=>'chain_job_1',job_type=>'CHAIN',job_action=>'my_chain1',
start_date=>sysdate,repeat_interval=>'freq=minutely;interval=1',enabled=>TRUE);
Note:單獨啟動job,注意參數USE_CURRENT_SESSION=>false
SQL> begin
2 dbms_scheduler.run_job(job_name=>'chain_job_1',USE_CURRENT_SESSION=>false);
SQL> selectjob_name,job_subname,status,req_start_date,actual_start_date fromuser_scheduler_job_run_details where job_name='CHAIN_JOB_1';
JOB_NAME JOB_SUBNAME STATUS REQ_START_DATE ACTUAL_START_DATE
--------------- ------------------------------ ----------------------------------------------------------------------------------------------------
CHAIN_JOB_1 STOPPED 16-JUN-16 03.44.03.000000 PM +08:00 16-JUN-16 03.44.03.588735 PM+08:00
CHAIN_JOB_1 MY_STEP1 FAILED 16-JUN-16 03.44.03.682508 PM +08:00 16-JUN-16 03.44.03.693946 PM+08:00
CHAIN_JOB_1 MY_STEP1 SUCCEEDED 16-JUN-16 04.17.43.335679 PM +08:00 16-JUN-16 04.17.43.436069 PM+08:00
發現my_step2還沒有運作
SQL> select * from test_chain1;
ID
----------
1
my_program1已寫入資料
制造my_step2啟動的條件
SQL> insert into test_chainvalues(9);
1 row created.
SQL> /
SQL> commit;
Commit complete.
--------------- ------------------------------ -------------------------------------------------- --------------------------------------------------
CHAIN_JOB_1 MY_STEP2 SUCCEEDED 16-JUN-16 04.30.43.064558 PM +08:00 16-JUN-16 04.30.43.152496 PM+08:00
CHAIN_JOB_1 MY_STEP1 SUCCEEDED 16-JUN-16 04.17.43.335679 PM +08:00 16-JUN-16 04.17.43.436069 PM+08:00
SQL> select * from test_chain2;
2