From 561751b4fd7d275bfd59b3e04ad28e5260464db3 Mon Sep 17 00:00:00 2001 From: Junjie <xjj@123> Date: 星期一, 10 二月 2025 14:57:55 +0800 Subject: [PATCH] # --- src/main/java/com/zy/asrs/task/WrkMastScheduler.java | 152 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 150 insertions(+), 2 deletions(-) diff --git a/src/main/java/com/zy/asrs/task/WrkMastScheduler.java b/src/main/java/com/zy/asrs/task/WrkMastScheduler.java index a54870d..4f1b40b 100644 --- a/src/main/java/com/zy/asrs/task/WrkMastScheduler.java +++ b/src/main/java/com/zy/asrs/task/WrkMastScheduler.java @@ -1,7 +1,9 @@ package com.zy.asrs.task; import com.baomidou.mybatisplus.mapper.EntityWrapper; +import com.zy.asrs.entity.LocMast; import com.zy.asrs.entity.WrkMast; +import com.zy.asrs.service.LocMastService; import com.zy.asrs.service.WrkMastLogService; import com.zy.asrs.service.WrkMastService; import com.zy.core.enums.WrkStsType; @@ -9,7 +11,9 @@ import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; +import org.springframework.transaction.annotation.Transactional; +import java.util.Date; import java.util.List; @@ -21,9 +25,152 @@ private WrkMastService wrkMastService; @Autowired private WrkMastLogService wrkMastLogService; + @Autowired + private LocMastService locMastService; @Scheduled(cron = "0/1 * * * * ? ") - private void executeMove(){ + @Transactional + public void executeIn(){ + List<WrkMast> wrkMasts = wrkMastService.selectList(new EntityWrapper<WrkMast>().eq("wrk_sts", WrkStsType.COMPLETE_INBOUND.sts)); + if (wrkMasts.isEmpty()) { + return; + } + + for (WrkMast wrkMast : wrkMasts) { + String locNo = wrkMast.getLocNo(); + LocMast locMast = locMastService.queryByLoc(locNo); + if (locMast == null) { + log.info("[workNo={}]搴撲綅涓嶅瓨鍦�", wrkMast.getWrkNo()); + continue; + } + + if (!locMast.getLocSts().equals("S")) { + log.info("[workNo={}]搴撲綅鐘舵�佷笉澶勪簬S", wrkMast.getWrkNo()); + continue; + } + + locMast.setLocSts("F"); + locMast.setModiTime(new Date()); + boolean result = locMastService.updateById(locMast); + if (!result) { + log.info("[workNo={}]搴撲綅鐘舵�丗鏇存柊澶辫触", wrkMast.getWrkNo()); + continue; + } + + // 淇濆瓨宸ヤ綔涓绘。鍘嗗彶妗� + if (!wrkMastLogService.save(wrkMast.getWrkNo())) { + log.info("淇濆瓨宸ヤ綔鍘嗗彶妗workNo={}]澶辫触", wrkMast.getWrkNo()); + } + // 鍒犻櫎宸ヤ綔涓绘。 + if (!wrkMastService.deleteById(wrkMast)) { + log.info("鍒犻櫎宸ヤ綔涓绘。[workNo={}]澶辫触", wrkMast.getWrkNo()); + } + } + } + + @Scheduled(cron = "0/1 * * * * ? ") + @Transactional + public void executeOut(){ + List<WrkMast> wrkMasts = wrkMastService.selectList(new EntityWrapper<WrkMast>().eq("wrk_sts", WrkStsType.COMPLETE_OUTBOUND.sts)); + if (wrkMasts.isEmpty()) { + return; + } + + for (WrkMast wrkMast : wrkMasts) { + String locNo = wrkMast.getSourceLocNo(); + LocMast locMast = locMastService.queryByLoc(locNo); + if (locMast == null) { + log.info("[workNo={}]搴撲綅涓嶅瓨鍦�", wrkMast.getWrkNo()); + continue; + } + + if (!locMast.getLocSts().equals("R")) { + log.info("[workNo={}]搴撲綅鐘舵�佷笉澶勪簬R", wrkMast.getWrkNo()); + continue; + } + + locMast.setLocSts("O"); + locMast.setModiTime(new Date()); + boolean result = locMastService.updateById(locMast); + if (!result) { + log.info("[workNo={}]搴撲綅鐘舵�丱鏇存柊澶辫触", wrkMast.getWrkNo()); + continue; + } + + // 淇濆瓨宸ヤ綔涓绘。鍘嗗彶妗� + if (!wrkMastLogService.save(wrkMast.getWrkNo())) { + log.info("淇濆瓨宸ヤ綔鍘嗗彶妗workNo={}]澶辫触", wrkMast.getWrkNo()); + } + // 鍒犻櫎宸ヤ綔涓绘。 + if (!wrkMastService.deleteById(wrkMast)) { + log.info("鍒犻櫎宸ヤ綔涓绘。[workNo={}]澶辫触", wrkMast.getWrkNo()); + } + } + } + + @Scheduled(cron = "0/1 * * * * ? ") + @Transactional + public void executeLocMove(){ + List<WrkMast> wrkMasts = wrkMastService.selectList(new EntityWrapper<WrkMast>().eq("wrk_sts", WrkStsType.COMPLETE_LOC_MOVE.sts)); + if (wrkMasts.isEmpty()) { + return; + } + + for (WrkMast wrkMast : wrkMasts) { + String sourceLocNo = wrkMast.getSourceLocNo(); + String locNo = wrkMast.getLocNo(); + LocMast locMast = locMastService.queryByLoc(locNo); + if (locMast == null) { + log.info("[workNo={}]搴撲綅涓嶅瓨鍦�", wrkMast.getWrkNo()); + continue; + } + + if (!locMast.getLocSts().equals("S")) { + log.info("[workNo={}]搴撲綅鐘舵�佷笉澶勪簬S", wrkMast.getWrkNo()); + continue; + } + + LocMast sourceLocMast= locMastService.queryByLoc(sourceLocNo); + if (sourceLocMast == null) { + log.info("[workNo={}]搴撲綅涓嶅瓨鍦�", wrkMast.getWrkNo()); + continue; + } + + if (!sourceLocMast.getLocSts().equals("R")) { + log.info("[workNo={}]搴撲綅鐘舵�佷笉澶勪簬R", wrkMast.getWrkNo()); + continue; + } + + locMast.setLocSts("F"); + locMast.setModiTime(new Date()); + boolean result = locMastService.updateById(locMast); + if (!result) { + log.info("[workNo={}]搴撲綅鐘舵�丗鏇存柊澶辫触", wrkMast.getWrkNo()); + continue; + } + + sourceLocMast.setLocSts("O"); + sourceLocMast.setModiTime(new Date()); + boolean result2 = locMastService.updateById(sourceLocMast); + if (!result2) { + log.info("[workNo={}]搴撲綅鐘舵�丱鏇存柊澶辫触", wrkMast.getWrkNo()); + continue; + } + + // 淇濆瓨宸ヤ綔涓绘。鍘嗗彶妗� + if (!wrkMastLogService.save(wrkMast.getWrkNo())) { + log.info("淇濆瓨宸ヤ綔鍘嗗彶妗workNo={}]澶辫触", wrkMast.getWrkNo()); + } + // 鍒犻櫎宸ヤ綔涓绘。 + if (!wrkMastService.deleteById(wrkMast)) { + log.info("鍒犻櫎宸ヤ綔涓绘。[workNo={}]澶辫触", wrkMast.getWrkNo()); + } + } + } + + @Scheduled(cron = "0/1 * * * * ? ") + @Transactional + public void executeMove(){ List<WrkMast> wrkMasts = wrkMastService.selectList(new EntityWrapper<WrkMast>().eq("wrk_sts", WrkStsType.COMPLETE_MOVE.sts)); if (wrkMasts.isEmpty()) { return; @@ -42,7 +189,8 @@ } @Scheduled(cron = "0/1 * * * * ? ") - private void executeCharge(){ + @Transactional + public void executeCharge(){ List<WrkMast> wrkMasts = wrkMastService.selectList(new EntityWrapper<WrkMast>().eq("wrk_sts", WrkStsType.COMPLETE_CHARGE.sts)); if (wrkMasts.isEmpty()) { return; -- Gitblit v1.9.1