2014-05-31 Created By BaoXinjian
一、摘要
Workflow中经常需要处理异常包括标准异常和自定义异常,进行处理时需要通过wf_core这个公用包进行处理
包含以下三个部分
二、案例
1. 定义一个处理Error的Exception Handing Program
2. 调用Workflow,触发此WF_CORE,以捕获该异常(wf_core.token, wf_core.context, wf_core.raise)
3. 查看wf_item_activity_status存放的error_name, error_message, error_stack
4. 其他信息,wf_resources存放common error
三、案例实现
需求: 自定义一个workflow exception,在调用workflow抛出,并将异常信息存放在wf_item_activity_status表中
1. 定义一个处理Error的Exception Handing Program
1 PROCEDURE invoice_exception_handing(itemtype VARCHAR2, 2
3 itemkey VARCHAR2, 4
5 actid NUMBER, 6
7 funcmode VARCHAR2, 8
9 resultout OUT NOCOPY VARCHAR2) IS
10
11 BEGIN
12
13 wf_core.token('bxj token arg1','bxj arg1_value'); 14
15 wf_core.token('bxj token arg2','bxj arg2_value'); 16
17 wf_core.context('bxj_wf_invoice_approve', 18
19 'invoice_exception_handing', 20
21 itemtype, 22
23 itemkey, 24
25 to_char(actid), 26
27 funcmode, 28
29 'bxj wf_core error <invoice exception handing>'); 30
31 wf_core.raise('bxj raise error'); 32
33 END;
2. 调用Workflow,触发此WF_CORE,以捕获该异常
3. 查看wf_item_activity_status存放的error_name, error_message, error_stack
(1). Error Name: bxj raise error
(2). Erorr Message: [bxj raise error] bxj token arg1=bxj arg1_value bxj token arg2=bxj arg2_value
(3). Error Stack:
bxj_wf_invoice_approve.invoice_exception_handing(BXJ_WF, BXJ_INVOICE_1004, 788470, RUN, bxj wf_core error <invoice exception handing>)
Wf_Engine_Util.Function_Call(bxj_wf_invoice_approve.invoice_exception_handing, BXJ_WF, BXJ_INVOICE_1004, 788470, RUN)
(4). 存放ErrorMessage
4. 其他信息,wf_resources存放common error,调用的时候只需将name当为参数输入即可,wf_resource表中也存在其他资料
Thanks and Regards