From 9f0fe04350c019c2ed1655d5b833648788734994 Mon Sep 17 00:00:00 2001 From: zhangc <zc@123> Date: 星期二, 14 一月 2025 16:34:51 +0800 Subject: [PATCH] 优化库位检索逻辑,移除冗余参数 --- src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java | 24 ++++++++++++++++++++---- 1 files changed, 20 insertions(+), 4 deletions(-) diff --git a/src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java index 6b192ba..2173736 100644 --- a/src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java @@ -4,6 +4,7 @@ import com.core.common.BaseRes; import com.core.common.Cools; import com.core.exception.CoolException; +import com.zy.asrs.constant.AsrsConstants; import com.zy.asrs.entity.*; import com.zy.asrs.entity.param.*; import com.zy.asrs.service.*; @@ -760,7 +761,7 @@ public String handBack(AgvMobileStartPakin param, Long userId) { Date now = new Date(); AgvWrkMast agvWrkMast = agvWrkMastService.selectOne(new EntityWrapper<AgvWrkMast>().eq("source_loc_no", param.getDevNo())); - if (agvWrkMast == null){ + if (agvWrkMast == null) { throw new CoolException("宸ヤ綔妗d腑娌℃湁姝ょ珯鐐逛换鍔�"); } agvWrkMast.setIoType(113); @@ -790,8 +791,23 @@ agvWrkMastLogService.save(agvWrkMast); agvWrkDetlLogService.save(agvWrkMast.getWrkNo()); String sourceLocNo = agvWrkMast.getSourceLocNo(); - AgvLocMast newLocMast = agvCommonService.getLocNo(3, 1, false, false); - if (newLocMast==null){ + + // TODO 鍥涙湡 + List<AgvWrkDetl> agvWrkDetls = agvWrkDetlService.selectList(new EntityWrapper<AgvWrkDetl>().eq("supp_code", param.getBarcode())); + String factory = null; + if (agvWrkDetls != null && !Cools.isEmpty(agvWrkDetls)) { + String orderNo = agvWrkDetls.get(0).getOrderNo(); + if (!Cools.isEmpty(orderNo)) { + if (orderNo.contains(AsrsConstants.ERCHANG)) { + factory = AsrsConstants.ERCHANG; + } else if (orderNo.contains(AsrsConstants.SANCHANG)) { + factory = AsrsConstants.SANCHANG; + } + } + } + AgvLocMast newLocMast = agvCommonService.getLocByLocRule(3, 1, factory); + //AgvLocMast newLocMast = agvCommonService.getLocNo(3, 1, false, false); + if (newLocMast == null) { throw new CoolException("鏃犲彲鐢ㄥ簱浣�"); } agvWrkMast.setSourceLocNo(agvWrkMast.getLocNo()); @@ -813,7 +829,7 @@ agvLocMastService.updateLocStsByLocNo(sourceLocNo, "O", "", (short) 30); agvLocDetlService.delete(new EntityWrapper<AgvLocDetl>().eq("loc_no", sourceLocNo)); - List<AgvWrkDetl> agvWrkDetls = agvWrkDetlService.selectList(new EntityWrapper<AgvWrkDetl>().eq("supp_code", param.getBarcode())); + //List<AgvWrkDetl> agvWrkDetls = agvWrkDetlService.selectList(new EntityWrapper<AgvWrkDetl>().eq("supp_code", param.getBarcode())); agvWrkDetls.forEach(agvWrkDetl -> { for (AgvWrkDetl wrkDetl : param.getWrkDetls()) { if (wrkDetl.getMatnr().equals(agvWrkDetl.getMatnr()) && wrkDetl.getThreeCode().equals(agvWrkDetl.getThreeCode())) { -- Gitblit v1.9.1