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

你可能感兴趣的:(workflow)