旺店通·企业奇门数据集成到金蝶云星空:采购入库同步方案
在电商和ERP系统的无缝对接中,确保数据准确传输和实时更新是至关重要的。本文将详细介绍如何通过使用轻易云平台,实现旺店通·企业奇门的数据与金蝶云星空的高效集成,这一过程涵盖了从数据获取、处理到最终写入的全流程管理。在这里,我们重点分享一个具体实例——“采购入库旺店通同步金蝶”的实施细节。
数据获取与分页处理
首先,我们需要从旺店通·企业奇门API接口wdt.stockin.order.query.purchase
中抓取采购入库订单数据。该接口允许我们根据特定条件查询已完成的采购订单,但由于其返回结果有一定限制,因此必须实现分页抓取以避免漏单问题。
{
"purchase_number": "20231001",
"start_time": "2023-10-01 00:00:00",
// 分页参数
"page_no": 1,
"page_size": 100
}
每次请求后,根据响应中的总记录数计算出需要多少页,并按顺序逐页拉取,直至所有数据全部获取完毕。同时,通过设置合理的限流策略,以应对旺店通接口调用频率的限制,确保不会因过度调用而导致IP被封或服务降级。
批量写入优化
当成功获取并整理好原始订单数据后,需要将这些信息快速批量写入到金蝶云星空。此时我们采用的是batchSave
API,该API允许一次性提交大批量的数据,提高了操作效率并减少了网络延迟带来的影响。
为了进一步增强可靠性,每次批量提交过程中,我们会记录操作日志,并进行错误重试。如果遇到部分失败,则仅重新尝试失败的数据条目,而不是重复整个批次,从而提升整体执行效率和稳定性。
{
"entries":[
{
"orderNumber":"PO123456789",
// more fields...
},
{
"orderNumber":"PO987654321",
// more fields...
}
// batch entries..
]
}
实时监控与日志记录
为了跟踪整个流程中的每个环节进展情况及快速定位问题,结合实时监控机制,通过轻易云平台提供的一些工具来生成细粒度日志。这种透明化操作不仅利于开发人员排查故障,还为运营团队提供及时反馈支持,使得业务运转更为平稳、安全。例如,当某个步骤发生异常时,可以即时通知相关负责人采取补救措施,而无需等待
调用旺店通·企业奇门接口获取并加工数据
在数据集成的生命周期中,调用源系统接口是至关重要的一步。本文将详细探讨如何通过轻易云数据集成平台调用旺店通·企业奇门接口wdt.stockin.order.query.purchase
,并对获取的数据进行初步加工。
接口调用配置
首先,我们需要配置接口调用的元数据。以下是对元数据配置的详细解析:
{
"api": "wdt.stockin.order.query.purchase",
"method": "POST",
"number": "order_no",
"id": "stockin_id",
"pagination": {
"pageSize": 50
},
"idCheck": true,
"omissionRemedy": {
"crontab": "44 * * * *",
"takeOverRequest": [
{
"field": "start_time",
"label": "开始时间",
"type": "datetime",
"value": "{{HOURE_AGO_1|datetime}}"
},
{
"field": "end_time",
"label": "结束时间",
"type": "datetime",
"value": "{{CURRENT_TIME|datetime}}"
}
]
},
...
}
- API和方法:
api
字段指定了要调用的接口为wdt.stockin.order.query.purchase
,请求方法为POST
。 - 标识字段:
number
和id
分别表示订单编号和入库单ID,用于唯一标识每条记录。 - 分页配置:通过
pagination.pageSize
设置每次请求返回的数据条数为50。 - ID检查:
idCheck: true
确保在处理过程中检查每条记录的唯一性。
请求参数配置
为了实现有效的数据请求,我们需要设置请求参数:
"request":[
{"field":"start_time","label":"开始时间","type":"datetime","value":"{{LAST_SYNC_TIME|datetime}}"},
{"field":"end_time","label":"结束时间","type":"datetime","value":"{{CURRENT_TIME|datetime}}"},
{"field":"status","label":"状态","type":"string"},
{"field":"src_order_no","label":"上层单据编号","type":"string"},
{"field":"warehouse_no","label":"仓库编号","type":"string"}
],
"otherRequest":[
{"field":"page_size","label":"分页大小","type":"string","value":"{PAGINATION_PAGE_SIZE}"},
{"field":"page_no","label":"页号","type":"string","value":"{PAGINATION_START_PAGE}"}
]
- 时间范围:通过动态变量设置开始时间和结束时间,确保每次同步时只获取最新的数据。
- 状态、上层单据编号、仓库编号等字段根据业务需求进行过滤。
- 分页参数:通过动态变量控制分页大小和页号,确保大数据量情况下的高效处理。
数据清洗与加工
在获取到原始数据后,需要进行初步清洗和加工,以便后续的数据转换与写入。以下是一些常见的数据清洗操作:
- 去重:根据唯一标识字段(如订单编号)去除重复记录。
- 格式转换:将日期、金额等字段转换为统一格式,确保数据一致性。
- 异常处理:过滤掉不符合业务规则或存在异常值的记录。
例如,对于日期字段,可以使用以下代码进行格式转换:
import datetime
def convert_date_format(date_str):
return datetime.datetime.strptime(date_str, '%Y-%m-%d %H:%M:%S').strftime('%Y%m%d')
异常补救机制
为了保证数据的完整性,我们还需要配置异常补救机制:
"omissionRemedy":{
...
}
通过定时任务(如每小时运行一次)重新请求遗漏的数据,并根据时间范围进行补充。这一机制可以有效避免由于网络波动或其他原因导致的数据丢失。
综上所述,通过合理配置元数据、请求参数以及实施必要的数据清洗与异常处理,可以高效地从旺店通·企业奇门接口获取并加工采购入库数据,为后续的数据转换与写入打下坚实基础。
使用轻易云数据集成平台进行ETL转换并写入金蝶云星空API接口
在数据集成生命周期的第二步中,我们将已经集成的源平台数据进行ETL(提取、转换、加载)处理,转为目标平台金蝶云星空API接口所能够接收的格式,并最终写入目标平台。本文将详细探讨如何通过轻易云数据集成平台实现这一过程。
配置API接口元数据
我们使用的API接口为batchSave
,通过POST方法提交数据,并启用ID检查功能。以下是具体的元数据配置:
{
"api": "batchSave",
"method": "POST",
"idCheck": true,
"operation": {
"rowsKey": "array",
"rows": 1,
"method": "batchArraySave"
},
"request": [
{
"field": "FBillTypeID",
"label": "单据类型",
"type": "string",
"parser": {
"name": "ConvertObjectParser",
"params": "FNumber"
},
"value": "RKD01_SYS"
},
{
...
}
],
...
}
数据字段解析与转换
每个字段都需要根据业务需求进行解析和转换。例如,FBillTypeID
字段表示单据类型,通过ConvertObjectParser
解析器将其值转换为金蝶云星空系统所需的格式:
{
"field": "FBillTypeID",
"label": "单据类型",
"type": "string",
"parser": {
"name": "ConvertObjectParser",
"params": "FNumber"
},
"value": "RKD01_SYS"
}
类似地,其他字段如FBillNo
(单据编号)、FDate
(入库日期)、FSupplierId
(供应商)等也需要进行相应的解析和转换。
嵌套对象与数组处理
对于嵌套对象和数组,需要特别注意其层级结构。例如,财务信息FInStockFin
字段包含多个子字段:
{
...
{
"field": "FInStockFin",
"label": "财务信息",
...
{
...
{
...
{
...
{
...
}
}
}
}
}
}
同样地,明细信息FInStockEntry
也是一个数组,其中包含多个子字段:
{
...
{
...
{
...
{
...
{
...
{
...
}
}
}
}
}
}
动态数据填充
在实际应用中,一些字段的数据需要动态填充。例如,通过查找集合来获取某些值:
{
...
{
...
{
...
"_findCollection find FTaxPrice from ... where FBillNo={outer_no} FMaterialId={{details_list.spec_no}}"
...
}
}
}
这段代码表示从指定集合中查找符合条件的数据并填充到相应字段。
提交与审核
最后,我们需要设置一些操作参数,例如是否自动提交并审核:
{
...
{
...
{"field":"IsAutoSubmitAndAudit","label":"提交并审核","type":"bool","value":"true"}
...
}
}
以上内容展示了如何通过轻易云数据集成平台配置元数据,实现将源平台的数据进行ETL转换,并最终写入目标平台金蝶云星空。通过合理配置API接口和解析器,可以确保数据无缝对接,提高业务效率。