Workflow_如何处理标准异常和自定义异常(案例)
2014-05-31 Created By BaoXinjian
一、摘要
Workflow中经常需要处理异常包括标准异常和自定义异常,进行处理时需要通过wf_core这个公用包进行处理
包含以下三个部分
- wf_core: 处理workflow中exception的标准包api
- wf_item_actvity_status:用以存放抛出的error_name, error_message, error_stack
- wf_resource: 存放了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
技术交流,技术讨论,欢迎加入
Technology Blog Created By Oracle ERP - 鲍新建