使用轻易云平台实现旺店通数据集成到MySQL

  • 轻易云集成顾问-彭萍
### 旺店通·旗舰奇门数据集成到MySQL:技术案例分享 在现代化电商运营中,数据流的高效管理和优化是企业成功的关键。本文将专注于一个具体的系统对接集成案例,即如何通过轻易云数据集成平台实现旺店通·旗舰奇门的数据高效集成到MySQL数据库中。本次案例实际运行方案名称为“旺店通旗舰版-销售出库单-->BI泰海-销售出库单表_原始查询(2024年起)”。 #### 技术背景与挑战 此次项目主要目标是利用 `wdt.wms.stockout.sales.querywithdetail` API接口,定时可靠地抓取旺店通·旗舰奇门中的销售出库单信息,并快速批量写入到MySQL,通过 `batchexecute` 完成交付。在这个过程中,我们需要解决以下技术难点: 1. **确保数据不漏单**: - 通过支持高吞吐量的数据写入能力,大量出库单能够被及时准确地传输至MySQL,提升了整个处理流程的时效性和可靠性。 2. **分页与限流处理**: - 使用自定义的分段获取逻辑,以应对API调用次数和频率限制,同时确保大规模数据可以顺利抓取。 3. **实时监控与异常检测**: - 集中的监控和告警系统可以实时跟踪每个数据集成任务,从而立即发现并处理任何可能出现的问题,保证整个流程稳定运行。 #### 数据格式转换及映射 由于旺店通·旗舰奇门与MySQL之间的数据结构存在差异,我们通过自定义数据转换逻辑,实现两边格式的一致。同时,通过轻易云提供的可视化操作界面,为复杂的数据流设计带来了极大的便利,使得业务需求转化为具体实施更加直观易管理。 这只是该项工作的开始部分,下文将继续详细探讨从API调度、分页策略,到错误重试机制等各个方面细节,实现完整、高效、安全的数据同步。 ![打通用友BIP数据接口](https://pic.qeasy.cloud/D8.png~tplv-syqr462i7n-qeasy.image) ### 调用旺店通·旗舰奇门接口wdt.wms.stockout.sales.querywithdetail获取并加工数据 在数据集成的生命周期中,调用源系统接口是至关重要的一步。本文将详细探讨如何通过轻易云数据集成平台调用旺店通·旗舰奇门接口`wdt.wms.stockout.sales.querywithdetail`,并对获取的数据进行初步加工。 #### 接口概述 接口`wdt.wms.stockout.sales.querywithdetail`用于查询销售出库单的详细信息。该接口采用POST方法进行请求,支持分页查询,并且能够根据时间范围过滤数据。以下是该接口的元数据配置: ```json { "api": "wdt.wms.stockout.sales.querywithdetail", "effect": "QUERY", "method": "POST", "number": "order_no", "id": "stockout_id", "name": "tid", "request": [ { "field": "pager", "label": "分页参数", "type": "object", "describe": "分页参数", "children": [ { "field": "page_size", "label": "分页大小", "type": "string", "describe": "分页大小", "value": "50" }, { "field": "page_no", "label": "页号", "type": "string", "describe": "页号", "value": "1" } ] }, { "field": "params", "label": "业务参数", "type": "object", "describe": "业务参数", 'children': [ { 'field': 'start_time', 'label': '开始时间', 'type': 'string', 'describe': '开始时间', 'value': '{{LAST_SYNC_TIME|datetime}}' }, { 'field': 'end_time', 'label': '结束时间', 'type': 'string', 'describe': '结束时间', 'value': '{{CURRENT_TIME|datetime}}' } ] } ], 'autoFillResponse': true, 'beatFlat': ['details_list'] } ``` #### 请求参数配置 在实际操作中,我们需要配置请求参数以便正确调用接口。请求参数主要包括分页参数和业务参数。 1. **分页参数**: - `page_size`: 每页返回的数据条数,默认值为50。 - `page_no`: 当前页码,默认值为1。 2. **业务参数**: - `start_time`: 查询的开始时间,使用上次同步时间(`{{LAST_SYNC_TIME|datetime}}`)。 - `end_time`: 查询的结束时间,使用当前时间(`{{CURRENT_TIME|datetime}}`)。 这些参数确保了我们能够按需获取指定时间范围内的销售出库单数据,并且支持分页处理大量数据。 #### 数据请求与清洗 在轻易云数据集成平台中,我们可以通过配置上述元数据来自动生成请求,并从旺店通·旗舰奇门系统中获取原始数据。以下是一个示例请求: ```json { 'pager': { 'page_size': '50', 'page_no': '1' }, 'params': { 'start_time': '{{LAST_SYNC_TIME|datetime}}', 'end_time': '{{CURRENT_TIME|datetime}}' } } ``` 一旦请求成功,我们将获得包含销售出库单详细信息的数据响应。由于配置了`autoFillResponse: true`和`beatFlat: ['details_list']`,平台会自动处理嵌套结构,将响应中的`details_list`字段平铺展开,以便后续的数据转换和写入操作。 #### 数据转换与写入 在获取并清洗了原始数据后,下一步是对数据进行转换和写入。这通常涉及将数据映射到目标系统所需的格式,并执行必要的数据转换逻辑。例如,将日期格式标准化、计算新增字段等。 假设目标系统是BI泰海,需要将销售出库单表导入其数据库。在此过程中,我们可能需要对字段进行重命名、类型转换等操作,以确保数据符合目标系统的要求。 #### 实践案例 以下是一个具体的实践案例,通过轻易云平台调用接口并处理返回的数据: 1. **配置元数据**:按照上述元数据配置,在轻易云平台中创建一个新的API调用任务。 2. **执行任务**:启动任务,平台会自动发送请求并接收响应。 3. **查看结果**:在平台界面上查看返回的数据,并验证是否符合预期。 4. **后续处理**:根据需要,对返回的数据进行进一步处理,如存储到数据库、生成报表等。 通过这种方式,我们可以高效地从旺店通·旗舰奇门系统中获取销售出库单详细信息,并将其集成到其他系统中,实现跨系统的数据共享和业务联动。 ![轻易云数据集成平台金蝶集成接口配置](https://pic.qeasy.cloud/S20.png~tplv-syqr462i7n-qeasy.image) ### 使用轻易云数据集成平台进行ETL转换并写入MySQL 在数据集成的生命周期中,第二步是将已经集成的源平台数据进行ETL(提取、转换、加载)转换,并转为目标平台 MySQL API 接口所能够接收的格式,最终写入目标平台。本文将详细探讨如何利用轻易云数据集成平台完成这一过程。 #### 数据提取与清洗 在进行数据转换之前,首先需要从源系统提取数据并进行必要的清洗。假设我们已经从旺店通旗舰版提取了销售出库单的数据,并且这些数据已经经过初步清洗和标准化处理。 #### 数据转换 接下来,我们需要将这些清洗后的数据转换为目标 MySQL 平台可以接受的格式。这里我们使用轻易云提供的元数据配置来定义字段映射和转换规则。 元数据配置如下: ```json { "api": "batchexecute", "effect": "EXECUTE", "method": "SQL", "number": "id", "id": "id", "name": "id", "idCheck": true, "request": [ {"field":"stockout_id","label":"出库单ID","type":"string","value":"{stockout_id}"}, {"field":"order_no","label":"出库单号","type":"string","value":"{order_no}"}, {"field":"src_order_no","label":"系统订单编号","type":"string","value":"{src_order_no}"}, {"field":"warehouse_no","label":"仓库编号","type":"string","value":"{warehouse_no}"}, {"field":"warehouse_name","label":"仓库名称","type":"string","value":"{warehouse_name}"}, {"field":"consign_time","label":"发货时间","type":"string","value":"{{consign_time|datetime}}"}, {"field":"order_type","label":"源单据类别","type":"string","value":"{order_type}"}, {"field":"goods_count","label":"货品数量","type":"string","value":"{goods_count}"}, {"field":"logistics_no","label":"物流单号","type":"string","value":"{logistics_no}"}, {"field":"receiver_name","label":"收件人姓名","type":"string","value":"{receiver_name}"}, {"field":...} ], "otherRequest":[ { "field": "main_sql", "label": "主语句", "type": "string", "describe": "SQL首次执行的语句,将会返回:lastInsertId", "value": `REPLACE INTO wms_stockout_sales_querywithdetail ( stockout_id, order_no, src_order_no, warehouse_no, warehouse_name, consign_time, order_type, goods_count, logistics_no, receiver_name, receiver_country, receiver_province, receiver_city, receiver_district, receiver_address, receiver_mobile, receiver_telno, receiver_zip, receiver_area, remark, weight, block_reason, logistics_type, logistics_code, logistics_name, shop_id, warehouse_id, logistics_id, bad_reason, receiver_dtb, refund_status, trade_type, salesman_no, fullname,picker_name, examiner_name,...) VALUES` }, { "field": "limit", "label": "limit", "type": "string", "value": "500" } ] } ``` 上述元数据配置中,`request`部分定义了每个字段的映射关系和类型,例如 `stockout_id` 对应 `出库单ID`,其类型为 `string`。`otherRequest` 部分则定义了 SQL 执行语句和其他参数,如批量处理限制等。 #### 数据加载 在完成数据转换后,下一步是将这些数据加载到 MySQL 中。我们使用 `batchexecute` API 来实现这一点。该 API 支持批量执行 SQL 语句,从而提高了性能和效率。 以下是一个示例 SQL 插入语句: ```sql REPLACE INTO wms_stockout_sales_querywithdetail ( stockout_id, order_no, src_order_no,...) VALUES (?, ?, ?, ...) ``` 通过轻易云的数据集成平台,我们可以自动生成并执行上述 SQL 插入语句,将转换后的数据批量写入 MySQL 数据库中。 #### 实践案例 假设我们有一条销售出库单记录如下: ```json { "stockout_id": "SO1234567890", ... } ``` 根据元数据配置,这条记录将被映射并插入到 MySQL 表 `wms_stockout_sales_querywithdetail` 中。具体操作步骤如下: 1. **提取数据**:从旺店通旗舰版提取销售出库单记录。 2. **清洗数据**:对提取的数据进行必要的清洗和标准化。 3. **转换数据**:根据元数据配置,将清洗后的数据映射到目标字段。 4. **加载数据**:使用 `batchexecute` API 批量执行 SQL 插入语句,将转换后的数据写入 MySQL 表中。 通过以上步骤,我们可以高效地完成从源系统到目标系统的数据集成,实现不同系统间的数据无缝对接。这不仅提高了业务透明度和效率,还确保了每个环节的数据准确性和一致性。 ![系统集成平台API接口配置](https://pic.qeasy.cloud/T3.png~tplv-syqr462i7n-qeasy.image)