分步解析MySQL数据到金蝶云星空的集成实现

  • 轻易云集成顾问-冯潇

MySQL数据集成到金蝶云星空案例分享:SD生产订单新增深圳天一-好

在现代企业的数据管理中,如何高效地实现MySQL数据库与ERP系统之间的数据流通是一个关键性课题。本次案例将重点探讨通过轻易云数据集成平台,将MySQL数据库中的生产订单数据可靠地集成到金蝶云星空(Kingdee Cloud Cosmic)内部的具体技术实现。

本方案命名为"SD生产订单新增深圳天一-好",其目标是在保障数据完整性和实时性的前提下,实现大规模的高吞吐量数据写入。首先,我们需要解决从MySQL获取数据并进行及时、准确处理的问题,尤其是接口调用的分页、限流以及异常处理机制等技术细节。

核心要点解析

  1. API接口调用方法

    • MySQL侧使用select API提取所需的生产订单数据。
    • 金蝶云星空采用batchSave API批量写入接收到的数据。
  2. 高效的数据抓取与传输: 通过定时任务设定可靠抓取MySQL接口中的新生成的生产订单信息。采用分页查询方式确保大量数据不会一次性过载,同时利用限流机制避免因瞬间压力导致系统响应缓慢或崩溃。

  3. 自定义转换逻辑与格式适配: 在实际操作中,源端(MySQL)和目的端(金蝶云星空)之间的数据结构通常存在差异。我们通过自定义转换逻辑,将不同来源字段一致化,并根据业务需求动态调整映射关系以满足特定场景要求,实现无缝对接。

  4. 实时监控与异常处理 结合轻易云平台提供的集中监控和告警功能,全程追踪每个集成任务状态,一旦发现问题立即触发预设应对策略,如错误重试或通知相关负责人,以减少因突发事件导致的数据丢失风险,从而最大化保证业务连续性。

以上,通过多个环节精细化配置及调优,使得整个流程不仅透明可见且具有高度灵活性,为后续深入优化提供了坚实基础。在继续探讨具体实施步骤之前,我们先来了解整体设计思路以及可能遇到的一些挑战... 用友与CRM系统接口开发配置

调用MySQL接口获取并加工数据的技术实现

在数据集成生命周期的第一步中,我们需要调用源系统MySQL接口,通过select语句获取并加工数据。以下将详细介绍如何在轻易云数据集成平台上配置和执行这一过程。

元数据配置解析

首先,我们来看一下元数据配置:

{
  "api": "select",
  "effect": "QUERY",
  "method": "POST",
  "number": "生产订单号",
  "id": "生产订单号",
  "idCheck": true,
  "request": [
    {
      "field": "main_params",
      "label": "main_params",
      "type": "object",
      "describe": "111",
      "value": "1",
      "children": [
        {
          "field": "limit",
          "label": "limit",
          "type": "string",
          "value": "100"
        },
        {
          "field": "offset",
          "label": "offset",
          "type": "string"
        }
      ]
    }
  ],
  ...
}

该配置定义了一个select类型的API调用,主要用于查询操作。请求方法为POST,并且指定了查询参数如limitoffset,以控制返回结果的数量和偏移量。

SQL查询语句

元数据中包含了一个复杂的SQL查询语句,用于从多个表中获取所需的数据:

SELECT 
 case m.delivery_org
  when 'T01.01' then  CONCAT('HJ', CAST(i.id AS CHAR))
 when 'T04'    then CONCAT('HJGD', CAST(i.id AS CHAR))
 else
   CONCAT('HJ', CAST(i.id AS CHAR))
 end as 生产订单号,
 a.mold_no AS 计划跟踪号,
 a.part_no AS 成品编号,
 if(weekday(i.create_time)=6,date_sub(i.create_time, interval 1 day),i.create_time) AS 计划开工时间,
 if(weekday(i.create_time)=6,date_sub(i.create_time, interval 1 day),i.create_time) AS 计划完工时间,
 i.id as sourceid,
 a.req_num AS 生产数量,
 m.delivery_org as 供应组织
FROM 
 mbs_nuclear_price_info i
 LEFT JOIN mbs_nuclear_price_task a ON i.nuclear_price_task_uuid = a.nuclear_price_task_uuid
 left join mbs_order_plan_bom l on a.mold_no=l.bom_no
 left join mbs_order_bom m on m.bom_uuid=l.bom_uuid
WHERE
 a.is_cancel = '1' 
 AND a.company_code = 'TYZN'
 AND i.create_time>(select config_value from sys_config where config_id=337)
 AND a.if_close = '1'
 AND ((i.out_type = '3' and TIMESTAMPDIFF(MINUTE,i.create_time,now())>=120) OR i.outsourced_type = '1') 
 and i.is_success !='1'
limit :limit offset :offset

该查询语句从多个表中联接获取数据,并根据特定条件进行筛选。特别地,它使用了条件判断、日期处理等高级SQL功能,以确保返回的数据符合业务需求。

请求参数设置

在请求参数部分,我们定义了两个主要参数:limitoffset。这些参数将被传递到SQL查询中,以控制返回结果的分页:

{
  ...
  {
    "field": "main_params",
    ...
    {
      "field": ":limit",
      ...
    },
    {
      ...
      ":offset"
    }
  }
}

通过这种方式,我们可以灵活地控制每次查询返回的数据量,从而有效管理大规模数据集的处理。

数据请求与清洗

在实际操作中,调用MySQL接口获取数据后,我们通常需要对原始数据进行清洗。这一步骤包括但不限于:

  • 去除无效或重复记录:确保每条记录都是唯一且有效的。
  • 格式转换:将日期、数字等字段转换为标准格式。
  • 字段映射:根据业务需求,将数据库字段映射到目标系统所需的字段。

例如,在上述SQL查询中,我们已经通过条件判断和日期处理对原始数据进行了初步清洗。

数据转换与写入

在完成数据请求与清洗后,下一步是将清洗后的数据转换并写入目标系统。这一步骤通常涉及以下操作:

  • 字段映射:将源系统中的字段映射到目标系统中的对应字段。
  • 格式转换:确保所有字段的数据类型和格式符合目标系统的要求。
  • 批量写入:将处理后的数据批量写入目标系统,以提高效率。

通过轻易云平台提供的全异步、多异构系统支持,我们可以轻松实现不同系统间的数据无缝对接,从而确保整个数据集成过程高效、可靠。

综上所述,通过合理配置元数据并利用轻易云平台强大的功能,我们可以高效地完成从MySQL接口获取并加工数据的任务,为后续的数据转换与写入打下坚实基础。 金蝶与MES系统接口开发配置

将源平台数据转换为金蝶云星空API接口格式并写入目标平台

在数据集成的生命周期中,ETL(提取、转换、加载)过程是至关重要的一环。本文将详细探讨如何使用轻易云数据集成平台,将已经集成的源平台数据进行ETL转换,最终转为金蝶云星空API接口所能够接收的格式,并写入目标平台。

API接口配置

根据提供的元数据配置,我们需要调用金蝶云星空的batchSave API接口。该接口采用POST请求方法,支持批量保存生产订单数据。以下是具体的请求字段及其配置:

  1. FBillNo(单据编号)

    • 类型:string
    • 描述:单据编号
    • 值:{{生产订单号}}
  2. FBillType(单据类型)

    • 类型:string
    • 描述:单据类型
    • 解析器:ConvertObjectParser
    • 参数:FNumber
    • 值:SCDD09_SYS
  3. Fdate(单据日期)

    • 类型:string
    • 描述:单据日期
    • 值:{{计划开工时间}}
  4. FPrdOrgId(生产组织)

    • 类型:string
    • 描述:生产组织
    • 解析器:ConvertObjectParser
    • 参数:FNumber
    • 值:
      _function  
      case '{{供应组织}}' 
       when 'T01.01' then 'T01.06'  
       when 'T04' then 'T04' 
       else '' 
      end
  5. FTreeEntity(明细): 明细字段是一个数组,包含多个子项。每个子项的具体字段如下:

    1. FMaterialId(物料编码)

      • 类型:string
      • 描述:子项物料编码
      • 解析器:ConvertObjectParser
      • 参数:FNumber
      • 值:{{成品编号}}
    2. Fqty(数量)

      • 类型:string
      • 描述:数量
      • 值:{{生产数量}}
    3. FProductType(产品类型)

      • 类型:string
      • 描述:产品类型
      • 值:1
    4. FPlanFinishDate(计划结束时间)

      • 类型:string
      • 描述:计划结束时间
      • 值:{{计划完工时间}}
    5. FPlanStartDate(计划开工时间)

      • 类型:string
      • 描述:计划开工时间
      • 值:{{计划开工时间}}
    6. FMTONO(计划跟踪号)

      • 类型:string
      • 描述:计划跟踪号
      • 值:{{计划跟踪号}}
    7. FWorkShopID(生产车间)

      • 类型:string
      • 描述:生产车间
      • 解析器:ConvertObjectParser
      • 参数:
        _function  
        case '{{供应组织}}' 
         when 'T01.01' then '13051101'  
         when 'T04' then 'TY880000' 
         else '' 
        end

其他请求参数

除了上述主要字段外,还需要配置一些其他请求参数:

  • FormId(业务对象表单Id)

    • 类型: string
    • 描述: 业务对象表单Id
    • 值: PRD_MO
  • Operation(执行的操作)

    • 类型: string
    • 描述: 执行的操作
    • 值: BatchSave
  • IsAutoSubmitAndAudit(提交并审核)

    • 类型: bool
    • 描述: 提交并审核
    • 值: false
  • IsVerifyBaseDataField(验证基础资料): – 类型: bool – 描述: 验证基础资料 – 值: true

数据转换与写入流程

  1. 提取数据: 从源平台提取所需的数据,包括生产订单号、计划开工时间、供应组织等。

  2. 数据清洗与转换: 使用轻易云的数据清洗功能,将提取的数据进行清洗和格式化。例如,将供应组织代码根据规则转换为目标平台所需的代码。

  3. 构建请求体: 根据上述API配置,将清洗后的数据映射到相应的字段中,构建符合金蝶云星空API要求的请求体。

  4. 发送请求并处理响应: 使用POST方法调用金蝶云星空的batchSave API,将构建好的请求体发送到目标平台,并处理返回结果。

通过上述步骤,我们可以实现将源平台的数据成功转换并写入到金蝶云星空系统中。这不仅确保了数据的一致性和准确性,也极大地提升了业务流程的自动化程度。 金蝶与外部系统打通接口