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 - 鲍新建
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?