From b0d15b88b0030e1ac64452ae76e571290a5f695b Mon Sep 17 00:00:00 2001 From: zhangchao <zc857179121@qq.com> Date: 星期二, 19 十一月 2024 13:32:41 +0800 Subject: [PATCH] 1 --- src/main/java/com/zy/asrs/task/AutoReplenishmentScheduler.java | 50 ++++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 40 insertions(+), 10 deletions(-) diff --git a/src/main/java/com/zy/asrs/task/AutoReplenishmentScheduler.java b/src/main/java/com/zy/asrs/task/AutoReplenishmentScheduler.java index d0ab451..8cf793a 100644 --- a/src/main/java/com/zy/asrs/task/AutoReplenishmentScheduler.java +++ b/src/main/java/com/zy/asrs/task/AutoReplenishmentScheduler.java @@ -3,19 +3,19 @@ import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.core.common.Cools; import com.zy.asrs.entity.DocType; +import com.zy.asrs.entity.LocDetl; import com.zy.asrs.entity.Mat; import com.zy.asrs.entity.Order; -import com.zy.asrs.service.AgvLocDetlService; -import com.zy.asrs.service.DocTypeService; -import com.zy.asrs.service.MatService; -import com.zy.asrs.service.OrderService; +import com.zy.asrs.service.*; import com.zy.asrs.task.handler.AutoReplenishmentHandler; +import com.zy.common.entity.Parameter; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; import java.util.List; +import java.util.Set; @Slf4j @Component @@ -31,29 +31,59 @@ private MatService matService; @Autowired private AgvLocDetlService agvLocDetlService; + @Autowired + private LocDetlService locDetlService; /* - 瀹氭椂渚垮埄搴撳瓨锛岀敓鎴愯嚜鍔ㄨˉ璐у崟鎹� + 瀹氭椂閬嶅巻搴撳瓨锛岀敓鎴愯嚜鍔ㄨˉ璐у崟鎹� */ - //@Scheduled(cron = "0/5 * * * * ? ") +// @Scheduled(cron = "0 */1 * * * ? ") public void createOrder(){ + + if(!"Y".equals(Parameter.get().getAutoReplenishment())){ + return; + } + //妫�娴嬫槸鍚︽湁鏈畬鎴愮殑琛ヨ揣鍗曟嵁 DocType docType = docTypeService.selectOne(new EntityWrapper<DocType>().eq("doc_name", "鑷姩琛ヨ揣鍗�")); int count = orderService.selectCount(new EntityWrapper<Order>() .eq("doc_type", docType.getDocId()) .andNew().eq("settle",2) - .or("settle",1)); + .or().eq("settle",1)); if(count > 0){ return; } //鏌ヨ鎵�鏈夐渶瑕佽ˉ璐х殑鐗╂枡 - List<Mat> matList = matService.selectList(new EntityWrapper<Mat>().eq(false, "store_min", 0)); + List<Mat> matList = matService.selectList(new EntityWrapper<Mat>().gt( "store_min", 0)); if(!Cools.isEmpty(matList)){ for (Mat mat : matList){ //鏌ヨ褰撳墠鐗╂枡鏄惁鍦╝gv搴撳皬浜庡簱瀛樹笂闄� Double anfmeSum = agvLocDetlService.selectSumAnfmeByMatnr(mat.getMatnr()); - if(anfmeSum < mat.getStoreMin()){ + if(Cools.isEmpty(anfmeSum)){ + anfmeSum = 0.0; + } + //褰撳墠鐗╂枡涓嶉渶瑕佽ˉ璐� + if(anfmeSum > mat.getStoreMin()){ + continue; + } + //鏌ヨ褰撳墠鐗╂枡鍥涢」搴撴槸鍚﹀瓨鍦�,骞朵笖璐ф灦涓嶅惈鏈夐潪璐ф灦鐗╂枡 + if(Cools.isEmpty(locDetlService.selectOne(new EntityWrapper<LocDetl>().eq("matnr", mat.getMatnr())))){ + continue; + } + + Set<String> locNosSearch = locDetlService.selectLocNos(mat.getMatnr()); + //鏄惁鍚湁鍙ˉ璐у嚭搴撶殑搴撲綅 + boolean flag = false; + for (String locNo : locNosSearch){ + //log.info("闇�瑕佹嫞鏂欑殑璐т綅锛�" + locNo +"锛岄渶瑕佽ˉ璐х殑鐗╂枡锛�" + mat.getMatnr()); + if(Cools.isEmpty(locDetlService.selectByLocWithoutContainer(locNo))){ + flag = true; + continue; + } + } + + if(flag){ autoReplenishmentHandler.create(mat,mat.getStoreMax() - anfmeSum); break; } @@ -64,7 +94,7 @@ /* 瀹氭椂澶勭悊鑷姩琛ヨ揣鍗曟嵁 */ - @Scheduled(cron = "0/5 * * * * ? ") + //@Scheduled(cron = "0/10 * * * * ? ") public void excuteOrder(){ DocType docType = docTypeService.selectOne(new EntityWrapper<DocType>().eq("doc_name", "鑷姩琛ヨ揣鍗�")); List<Order> orderList = orderService.selectList(new EntityWrapper<Order>() -- Gitblit v1.9.1