From 3c1e34e86e18224acf34883039f7c31cab5a3d4d Mon Sep 17 00:00:00 2001 From: zyx <zyx123456> Date: 星期二, 19 九月 2023 16:28:44 +0800 Subject: [PATCH] 平库增加 --- src/main/java/com/zy/common/service/CommonService.java | 80 ++++++++++++++++++++++++--------------- 1 files changed, 49 insertions(+), 31 deletions(-) diff --git a/src/main/java/com/zy/common/service/CommonService.java b/src/main/java/com/zy/common/service/CommonService.java index d62cd45..ed76694 100644 --- a/src/main/java/com/zy/common/service/CommonService.java +++ b/src/main/java/com/zy/common/service/CommonService.java @@ -144,6 +144,8 @@ //鎵惧埌搴撲綅锛岃繑鍥瀌to return getLocNoStep6(staDescId, sourceStaNo, locMast);//杩斿洖dto } + // 鏍规嵁鐗╂枡棰戠巼鏌ヨ搴撲綅 + // 濡傛灉娌℃湁鐩歌繎鐗╂枡锛屽垯鎸夎鍒欒疆璇㈣揣鏋� // 寮�濮嬫煡鎵惧簱浣� ==============================>> @@ -161,8 +163,6 @@ * 娣疯浇鎵惧簱浣� */ private LocMast getLocNoStep1(List<String> matNos, LocTypeDto locTypeDto) { - LocMast locMast = null; - //鍒ゆ柇褰撳墠璐х墿鏄惁涓烘贩杞借揣鐗� String firstMatNos = matNos.get(0); boolean mixed = false;//榛樿涓嶆槸娣疯浇璐х墿 @@ -174,41 +174,44 @@ } if (!mixed) { - return locMast;//涓嶆槸娣疯浇璐х墿锛岀洿鎺ヨ烦鍑哄綋鍓嶄换鍔� + return null;//涓嶆槸娣疯浇璐х墿锛岀洿鎺ヨ烦鍑哄綋鍓嶄换鍔� } // 鎵炬贩杞藉簱浣嶈鍒� - LocRule locRule = locRuleService.findMixed(); - if (locRule == null) { - return locMast;//娌℃湁娣疯浇瑙勫垯锛岃烦鍑哄綋鍓嶄换鍔� + List<LocRule> locRules = locRuleService.findMixed(); + if (locRules == null || locRules.size() == 0) { + return null;//娌℃湁娣疯浇瑙勫垯锛岃烦鍑哄綋鍓嶄换鍔� } - //灏嗗簱浣嶈鍒欑粍杞崲涓哄簱浣嶇粍 - List<LocMast> locMasts = locRuleService.locRuleToLocNos(locRule); - if (locMasts == null || locMasts.size() == 0) { - if (locRule.getKeepGo() == 0) { - //鎵句笉鍒扮┖搴撲綅锛屼笖绂佹缁х画瀵绘壘鍏朵粬闈炴贩杞藉尯鍩熷簱浣� - //鎵句笉鍒板簱浣嶏紝鎶涘嚭寮傚父 - throw new CoolException("娣疯浇鍖哄煙娌℃湁绌哄簱浣�"); + for (LocRule locRule : locRules) { + if (locRule == null) { + continue; } - return locMast;//娌℃湁娣疯浇瑙勫垯锛岃烦鍑哄綋鍓嶄换鍔� - } - for (LocMast one : locMasts) { - LocMast locMast0 = locMastService.findOutMost(one.getLocNo()); - if (null != locMast0) { - // 娴呭簱浣嶇鍚堝昂瀵告娴� - if (VersionUtils.locMoveCheckLocType(locMast0, locTypeDto)) { - // 鍥犲簱浣嶇Щ杞�侀渶棰勭暀绌哄簱浣� - if (locMastService.checkEmptyCount(locMast0, 10)) { - locMast = locMast0; - break; + List<LocMast> locMasts = locMastService.queryFreeLocMast2(locTypeDto.getLocType1(), locRule.getRowBeg(), locRule.getRowEnd(), locRule.getBayBeg(), locRule.getBayEnd(), locRule.getLevBeg(), locRule.getLevEnd()); + + for (LocMast one : locMasts) { + LocMast locMast0 = locMastService.findOutMost(one.getLocNo()); + if (null != locMast0) { + // 娴呭簱浣嶇鍚堝昂瀵告娴� + if (VersionUtils.locMoveCheckLocType(locMast0, locTypeDto)) { + // 鍥犲簱浣嶇Щ杞�侀渶棰勭暀绌哄簱浣� + if (locMastService.checkEmptyCount(locMast0, 10)) { + return locMast0;//鎵惧埌绌轰綑鐨勬贩杞藉簱浣� + } } } } + } - return locMast; + if (locRules.get(0).getKeepGo() == 0) { + //鎵句笉鍒扮┖搴撲綅锛屼笖绂佹缁х画瀵绘壘鍏朵粬闈炴贩杞藉尯鍩熷簱浣� + //鎵句笉鍒板簱浣嶏紝鎶涘嚭寮傚父 + throw new CoolException("娣疯浇鍖哄煙娌℃湁绌哄簱浣�"); + } + + return null; } /** @@ -217,8 +220,16 @@ private LocMast getLocNoStep2(List<String> matNos, LocTypeDto locTypeDto) { LocMast locMast = null; // 搴撳尯閿佸畾 - LocRule locRule = locRuleService.find(Cools.isEmpty(matNos) ? null : matNos.get(0)); - if (!Cools.isEmpty(locRule)) { + List<LocRule> locRules = locRuleService.find(Cools.isEmpty(matNos) ? null : matNos.get(0)); + if (locRules == null || locRules.size() == 0) { + return null;//娌℃湁搴撲綅瑙勫垯锛岃烦鍑哄綋鍓嶄换鍔� + } + + for (LocRule locRule : locRules) { + if (locRule == null) { + continue; + } + List<LocMast> locMasts = locMastService.queryFreeLocMast2(locTypeDto.getLocType1(), locRule.getRowBeg(), locRule.getRowEnd(), locRule.getBayBeg(), locRule.getBayEnd(), locRule.getLevBeg(), locRule.getLevEnd()); for (LocMast one : locMasts) { LocMast locMast0 = locMastService.findOutMost(one.getLocNo()); @@ -227,13 +238,19 @@ if (VersionUtils.locMoveCheckLocType(locMast0, locTypeDto)) { // 鍥犲簱浣嶇Щ杞�侀渶棰勭暀绌哄簱浣� if (locMastService.checkEmptyCount(locMast0, 10)) { - locMast = locMast0; - break; + return locMast0; } } } } } + + if (locRules.get(0).getKeepGo() == 0) { + //鎵句笉鍒扮┖搴撲綅锛屼笖绂佹缁х画瀵绘壘鍏朵粬闈炴贩杞藉尯鍩熷簱浣� + //鎵句笉鍒板簱浣嶏紝鎶涘嚭寮傚父 + throw new CoolException("瑙勫垯鍖哄煙娌℃湁绌哄簱浣�"); + } + return locMast; } @@ -337,11 +354,12 @@ //杩斿洖dto private StartupDto getLocNoStep6(Integer staDescId, Integer sourceStaNo, LocMast locMast) { StartupDto startupDto = new StartupDto(); - + String locNo = locMast.getLocNo(); // 鑾峰彇鐩爣绔� Wrapper<StaDesc> wrapper = new EntityWrapper<StaDesc>() .eq("type_no", staDescId) - .eq("stn_no", sourceStaNo); + .eq("stn_no", sourceStaNo) + .eq("crn_no",Utils.getLev(locNo));//鍊熺敤鍫嗗灈鏈哄彿瀛楁鍏呭綋妤煎眰鍙� StaDesc staDesc = staDescService.selectOne(wrapper); if (Cools.isEmpty(staDesc)) { log.error("鍏ュ簱璺緞涓嶅瓨鍦�, staDescId={}, sourceStaNo={}", staDescId, sourceStaNo); -- Gitblit v1.9.1