2014-05-31 BaoXinjian In Capgemini

一、摘要

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) IS10 11 BEGIN12 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 ‘);30 31 wf_core.raise(‘bxj raise error’);32 33 END;

 

  1. 调用Workflow,触发此WF_CORE,以捕获该异常

    图片 1 

  1. 查看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

    图片 2 

  1. 其他信息,wf_resources存放common
    error,调用的时候只需将name当为参数输入即可,wf_resource表中也存在其他资料

    图片 3 

 Thanks and Regards

图片 4

相关文章