From 0bbd986930e4b41e0741fd07c4287208da398330 Mon Sep 17 00:00:00 2001 From: zhangherong <571457620@qq.com> Date: 星期五, 01 八月 2025 17:03:37 +0800 Subject: [PATCH] art: 生产订单同步定时任务 --- src/main/java/org/jeecg/modules/pms/service/impl/PmsMaterialProcessServiceImpl.java | 34 +++++++++++++++++++++++++++++++++- 1 files changed, 33 insertions(+), 1 deletions(-) diff --git a/src/main/java/org/jeecg/modules/pms/service/impl/PmsMaterialProcessServiceImpl.java b/src/main/java/org/jeecg/modules/pms/service/impl/PmsMaterialProcessServiceImpl.java index 3629fc2..876678d 100644 --- a/src/main/java/org/jeecg/modules/pms/service/impl/PmsMaterialProcessServiceImpl.java +++ b/src/main/java/org/jeecg/modules/pms/service/impl/PmsMaterialProcessServiceImpl.java @@ -1,22 +1,29 @@ package org.jeecg.modules.pms.service.impl; +import cn.hutool.core.collection.CollectionUtil; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import org.apache.commons.lang.StringUtils; +import org.jeecg.modules.mes.entity.MesProductionOrder; import org.jeecg.modules.pms.entity.PmsMaterialProcess; import org.jeecg.modules.pms.mapper.PmsMaterialProcessMapper; import org.jeecg.modules.pms.service.IPmsMaterialProcessService; +import org.jeecg.modules.sap.dto.OrderProcessDTO; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; import javax.servlet.http.HttpServletRequest; import java.util.HashMap; +import java.util.List; import java.util.Map; +import java.util.stream.Collectors; /** * @Description: 鐗╂枡宸ュ簭 * @Author: jeecg-boot - * @Date: 2025-07-01 + * @Date: 2025-07-01 * @Version: V1.0 */ @Service @@ -40,4 +47,29 @@ } return super.getBaseMapper().getpmsMaterialProcessListData(pageData, paramMap); } + + @Override + @Transactional(rollbackFor = Exception.class) + public boolean saveOrUpdateOrderProcess(Map<String, MesProductionOrder> orderMap, List<OrderProcessDTO> orderProcessDTOList) { + for (Map.Entry<String, MesProductionOrder> entry : orderMap.entrySet()) { + MesProductionOrder order = entry.getValue(); + //鍒犻櫎鍘熸湁鐨勬暟鎹� + this.removeByOrderId(order.getId()); + //閲嶆柊鏂板宸ュ簭淇℃伅 + List<OrderProcessDTO> collect = orderProcessDTOList.stream().filter(orderProcessDTO -> entry.getKey().equals(orderProcessDTO.getAUFNR())).collect(Collectors.toList()); + if (CollectionUtil.isNotEmpty(collect)) { + List<PmsMaterialProcess> list = collect.stream().map(orderBomDTO -> new PmsMaterialProcess(entry.getKey(), order.getMaterialName(), orderBomDTO)).collect(Collectors.toList()); + super.saveBatch(list); + } + } + return true; + } + + @Override + @Transactional(rollbackFor = Exception.class) + public void removeByOrderId(String orderId) { + LambdaQueryWrapper<PmsMaterialProcess> queryWrapper = new LambdaQueryWrapper<>(); + queryWrapper.eq(PmsMaterialProcess::getOrderId, orderId); + super.remove(queryWrapper); + } } -- Gitblit v1.9.3