如何通过服务流程进行单据反写

服务流程是集成云推出的面向复杂集成场景的低代码服务编排工具,能够把已有的集成对象、集成方案、消息服务、API接口等集成资源,通过流程化设计编排成全新的应用服务,以支持更加复杂的业务场景。
例如基础数据分发到多个系统、数据消费需要从多源取数、基于某个数据参数处理不同的集成过程等等。
为了帮助大家快速掌握服务流程的使用方法,我们推出了系列文章,通过11个典型案例向大家介绍服务流程的高级技巧。
在上期集成服务流程经典案例系列文章“如何使用服务流程对启动方案失败进行自动补偿”中,我们为大家介绍了服务流程的第三个经典案例:如何在服务流程中进行失败单据补偿。
本期,小编继续为大家介绍第4个案例:如何通过服务流程进行单据反写,包括以下3个要点:
单据反写案例需求背景
如何根据反写背景来配置服务流程属性
如何通过监听操作,完成单据之间的回写与反写流程
1 单据反写需求背景
本篇文章将以集成云的演示demo中的基础资料demo1集成到基础资料demo2为例(后文简称demo1、demo2),为大家介绍单据反写的背景及操作方法。
单据反写的需求背景如下:
创建demo1保存事件监听服务流程。当基础资料demo1进行保存操作时,触发该服务流程,将demo1的单据信息同步至demo2,并将是否同步成功回写到demo1的别名字段上(此处使用别名字段便于演示)。

业务流程
注意事项:
实际使用时,单据A与单据B应当分别处于不同的系统。本案例为方便起见,使用了当前系统的demo1和demo2代替。
同时,本案例仅提供主要的业务分析与服务流程设计思路。在具体应用时,应根据现场实际业务需求调整服务流程节点和流程路线的设计。
2 设置服务流程属性
2.1 配置服务流程属性和变量
首先,由于需要监听实体上的事件,应将服务流程的【启动方式】设置为“事件触发”。

启动方式
在【流程变量】添加变量“demo1”和“demo2”用以存储获取的数据和加载的数据,“demo1feedback”用以存储数据加载的反馈信息。

流程变量示例
在【依赖资源】下将取数和写数的集成对象(数据来源)作为依赖资源引入服务流程中。

依赖资源示例
3 服务流程节点解析

服务流程图概览
3.1 开始节点 —— demo1保存
配置需要监听的集成对象和相应单据事件,以及需要的取出字段,将获取到的数据赋值给流程变量“demo1”。


开始节点-事件触发
3.2 字段映射 —— demo1映射到demo2
通过字段映射节点配置流程变量“demo1”和“demo2”之间的映射关系,将流程变量“demo1”的数据赋值给流程变量“demo2”。


字段映射节点
3.3 数据加载 —— 写入demo2
通过配置数据加载节点,在节点中定义目标对象上的操作,以及用以判断数据唯一性的候选键,将流程变量“demo2”上的数据写入目标集成对象。


数据加载节点-写入demo2
3.4 错误转移 —— 捕获异常与组装回调信息
通过错误转移将加载数据中抛出的错误进行捕获,然后使用脚本节点分别构造加载成功和加载失败的信息。
接着,将空map赋值给流程变量“demo1feed
如何通过服务流程进行单据反写
声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。如若本站内容侵犯了原著者的合法权益,可联系本站删除。



