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

posted on 2014-07-09 21:53  东方瀚海  阅读(1030)  评论(0编辑  收藏  举报