From f68d3c71819feb59e7a227a5d992b059b900916c Mon Sep 17 00:00:00 2001 From: ZengTao <2773468879@qq.com> Date: 星期五, 28 三月 2025 08:28:26 +0800 Subject: [PATCH] 修改报表,界面添加查询流程卡个数,调整推送数据到前端的间隔 --- hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/job/PlcStorageCageTask.java | 1027 +++++++++++++++++++++++++++++++++++++++++++++++--------- 1 files changed, 850 insertions(+), 177 deletions(-) diff --git a/hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/job/PlcStorageCageTask.java b/hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/job/PlcStorageCageTask.java index c942166..351ca33 100644 --- a/hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/job/PlcStorageCageTask.java +++ b/hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/job/PlcStorageCageTask.java @@ -2,6 +2,7 @@ import cn.hutool.core.lang.Assert; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; import com.baomidou.mybatisplus.core.toolkit.CollectionUtils; import com.github.yulichang.toolkit.JoinWrappers; @@ -31,6 +32,8 @@ import com.mes.temperingglass.entity.TemperingGlassInfo; import com.mes.temperingglass.service.TemperingGlassInfoService; import com.mes.tools.S7control; +import com.mes.utils.RedisUtil; +import io.swagger.models.auth.In; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang.StringUtils; import org.springframework.beans.BeanUtils; @@ -66,6 +69,9 @@ @Resource private DamageService damageService; + @Resource + private RedisUtil redisUtil; + private static final String REQUEST_WORD = "1"; @Value("${mes.sequence.order}") @@ -93,6 +99,9 @@ private String d01GlassId = ""; private String d04GlassId = ""; + private List<BigStorageCageOutTask> allTask = new ArrayList<>(); + private List<BigStorageCageOutTask> notAllTask = new ArrayList<>(); + @Scheduled(fixedDelay = 300) public void plcToHomeEdgScan() { Date startDate = new Date(); @@ -111,6 +120,11 @@ String d01ToMES = plcParameterObject.getPlcParameter("D01ToMES").getValue(); String d04ToMES = plcParameterObject.getPlcParameter("D04ToMES").getValue(); + +// d01Id="P25010108|37|8"; +// d04ToMES="1"; +// d01ToMES="1"; + log.info("1銆佽幏鍙杁01Id鎵弿ID涓猴細{}锛岃姹傚瓧涓簕};鑾峰彇d04Id鎵弿ID涓猴細{}锛岃姹傚瓧涓簕};", d01Id, d01ToMES, d04Id, d04ToMES); if (StringUtils.isBlank(d01ToMES) && StringUtils.isBlank(d04ToMES)) { log.info("涓ゆ潯绾挎湭鏀跺埌杩涚墖浠诲姟锛岀粨鏉熸湰娆℃壂鎻忚繘鍗ц浆绔嬩换鍔�"); @@ -120,19 +134,68 @@ log.info("涓ゆ潯绾垮崸杞珛鍧囧湪鎵ц浠诲姟锛岀粨鏉熸湰娆℃壂鎻忚繘鍗ц浆绔嬩换鍔�"); return; } +// if (REQUEST_WORD.equals(d01ToMES)) { +// List<BigStorageCageFeedTask> bigStorageCageFeedTasks = bigStorageCageFeedTaskService.list( +// new LambdaQueryWrapper<BigStorageCageFeedTask>() +// .gt(BigStorageCageFeedTask::getTargetSlot, 0) +// .eq(BigStorageCageFeedTask::getLine, Const.A09_OUT_TARGET_POSITION) +// .eq(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_NEW) +// .eq(BigStorageCageFeedTask::getGlassId, d01Id) +// ); +// if (CollectionUtils.isNotEmpty(bigStorageCageFeedTasks)) { +// S7object.getinstance().plccontrol.writeWord(mesD01Address, 1); +// } +// log.info("{}绾垮啀娆″彂閫佽繘鐗囧惎鍔�", Const.A09_OUT_TARGET_POSITION); +// return; +// } +// if (REQUEST_WORD.equals(d04ToMES)) { +// List<BigStorageCageFeedTask> bigStorageCageFeedTasks = bigStorageCageFeedTaskService.list( +// new LambdaQueryWrapper<BigStorageCageFeedTask>() +// .gt(BigStorageCageFeedTask::getTargetSlot, 0) +// .eq(BigStorageCageFeedTask::getLine, Const.A10_OUT_TARGET_POSITION) +// .eq(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_NEW) +// .eq(BigStorageCageFeedTask::getGlassId, d01Id) +// ); +// if (CollectionUtils.isNotEmpty(bigStorageCageFeedTasks)) { +// S7object.getinstance().plccontrol.writeWord(mesD04Address, 1); +// } +// log.info("{}绾垮啀娆″彂閫佽繘鐗囧惎鍔�", Const.A10_OUT_TARGET_POSITION); +// return; +// } //鎸夌収绾胯矾鍙婄幓鐠僫d鑾峰彇鐩搁偦涓ゅ潡鐜荤拑 鍗ц浆绔嬩笂鐨勭幓鐠�: 鐘舵�佷负0涓嶆搷浣滐紙D01閫佺墖锛�0涓嶆搷浣滐紝1鍏佽閫佺墖锛夛紝璇锋眰瀛椾负1锛� 锛�02鐜荤拑id涓虹┖鎴栬�呭崸杞珛鏈惎鍔級 if (!REQUEST_WORD.equals(mesD01Value) && REQUEST_WORD.equals(d01ToMES) && (StringUtils.isBlank(d02State) || !REQUEST_WORD.equals(d03State))) { - if (!d01GlassId.equals(d01Id)) { - judgeGlassTypeStatus(d01Id, Const.A09_OUT_TARGET_POSITION, mesD01Address); - d01GlassId = d01Id; + List<BigStorageCageFeedTask> bigStorageCageFeedTasks = bigStorageCageFeedTaskService.list( + new LambdaQueryWrapper<BigStorageCageFeedTask>() + .gt(BigStorageCageFeedTask::getTargetSlot, 0) + .eq(BigStorageCageFeedTask::getLine, Const.A09_OUT_TARGET_POSITION) + .eq(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_UP) + ); + if (CollectionUtils.isEmpty(bigStorageCageFeedTasks)) { + if (!d01GlassId.equals(d01Id)) { + judgeGlassTypeStatus(d01Id, Const.A09_OUT_TARGET_POSITION, mesD01Address); + edgGlassTaskInfoService.update(new LambdaUpdateWrapper<EdgGlassTaskInfo>() + .set(EdgGlassTaskInfo::getStatus, Const.EDG_GLASS_SUCCESS).eq(EdgGlassTaskInfo::getGlassId, d01Id)); +// d01GlassId = d01Id; + } } } // 鐘舵�佷负0涓嶆搷浣滐紙D01閫佺墖锛�0涓嶆搷浣滐紝1鍏佽閫佺墖锛夛紝璇锋眰瀛椾负1锛� 鍗ц浆绔嬫湭鍚姩 if (!REQUEST_WORD.equals(mesD04Value) && REQUEST_WORD.equals(d04ToMES) && !REQUEST_WORD.equals(d05State)) { - if (!d04GlassId.equals(d04Id)) { - judgeGlassTypeStatus(d04Id, Const.A10_OUT_TARGET_POSITION, mesD04Address); - d04GlassId = d04Id; + List<BigStorageCageFeedTask> bigStorageCageFeedTasks = bigStorageCageFeedTaskService.list( + new LambdaQueryWrapper<BigStorageCageFeedTask>() + .gt(BigStorageCageFeedTask::getTargetSlot, 0) + .eq(BigStorageCageFeedTask::getLine, Const.A10_OUT_TARGET_POSITION) + .eq(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_UP) + ); + if (CollectionUtils.isEmpty(bigStorageCageFeedTasks)) { + if (!d04GlassId.equals(d04Id)) { + judgeGlassTypeStatus(d04Id, Const.A10_OUT_TARGET_POSITION, mesD04Address); + edgGlassTaskInfoService.update(new LambdaUpdateWrapper<EdgGlassTaskInfo>() + .set(EdgGlassTaskInfo::getStatus, Const.EDG_GLASS_SUCCESS).eq(EdgGlassTaskInfo::getGlassId, d04Id)); +// d04GlassId = d04Id; + } } + } Date endDate = new Date(); log.info("澶х悊鐗囩鎵爜浠诲姟缁撴潫鏃堕棿锛歿}锛屽叡鑰楁椂锛歿}ms,缁撴潫鎵爜浠诲姟", endDate, endDate.getTime() - startDate.getTime()); @@ -142,11 +205,29 @@ public void plcToHomeEdgFreeCarTask() { Date startDate = new Date(); log.info("澶х悊鐗囩绌鸿溅杩涚墖浠诲姟寮�濮嬫墽琛屾椂闂达細{}", startDate); + + PlcParameterObject plcMesObject = S7object.getinstance().PlcMesObject; + String mesD03Address = plcMesObject.getPlcParameter("MESToD03").getValue(); + String mesD05Address = plcMesObject.getPlcParameter("MESToD05").getValue(); + log.info("MESToD03:{},MESToD05:{}", mesD03Address, mesD05Address); + if ("2".equals(mesD03Address) || "2".equals(mesD05Address)) { + log.info("鏈夊惎鍔ㄤ俊鍙凤紝MESToD03:{},MESToD05:{}", mesD03Address, mesD05Address); + } PlcParameterObject plcParameterObject = S7object.getinstance().PlcMesObject; String e01Status = plcParameterObject.getPlcParameter("E01State").getValue(); String d03ToMES = plcParameterObject.getPlcParameter("D03ToMES").getValue(); String d05ToMES = plcParameterObject.getPlcParameter("D05ToMES").getValue(); log.info("鎵ц绌鸿溅閫佺墖浠诲姟锛岃幏鍙栧埌鐨勫ぇ杞︾姸鎬佷负{}锛屽崸杞珛鐘舵�佸垎鍒负d03:{}锛宒05:{}", e01Status, d03ToMES, d05ToMES); + List<BigStorageCageFeedTask> bigStorageCageFeedTasks = bigStorageCageFeedTaskService.list( + new LambdaQueryWrapper<BigStorageCageFeedTask>() + .ne(BigStorageCageFeedTask::getTargetSlot, 0) + .lt(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_SLOT) + ); + if (bigStorageCageFeedTasks.size() > 0) { + Date endDate = new Date(); + log.info("澶ц溅鏈夋鍦ㄦ墽琛岀殑浠诲姟{}锛岀粨鏉熼�佺墖浠诲姟锛屼换鍔$粨鏉熸椂闂达細{}锛屽叡鑰楁椂锛歿}ms,缁撴潫鎵爜浠诲姟", bigStorageCageFeedTasks, endDate, endDate.getTime() - startDate.getTime()); + return; + } if (REQUEST_WORD.equals(e01Status)) { Date endDate = new Date(); log.info("杩涚墖澶ц溅闈炵┖闂诧紝缁撴潫閫佺墖浠诲姟锛屼换鍔$粨鏉熸椂闂达細{}锛屽叡鑰楁椂锛歿}ms,缁撴潫鎵爜浠诲姟", endDate, endDate.getTime() - startDate.getTime()); @@ -154,13 +235,21 @@ } if (!REQUEST_WORD.equals(d03ToMES) && !REQUEST_WORD.equals(d05ToMES)) { Date endDate = new Date(); - log.info("鍗ц浆绔嬫病鏈夐�佺墖璇锋眰锛岀粨鏉熼�佺墖浠诲姟锛屼换鍔$粨鏉熸椂闂达細{}锛屽叡鑰楁椂锛歿}ms,缁撴潫鎵爜浠诲姟", endDate, endDate.getTime() - startDate.getTime()); + log.info("鍗ц浆绔嬬涓�娆℃病鏈夐�佺墖璇锋眰锛岀粨鏉熼�佺墖浠诲姟锛屼换鍔$粨鏉熸椂闂达細{}锛屽叡鑰楁椂锛歿}ms,缁撴潫鎵爜浠诲姟", endDate, endDate.getTime() - startDate.getTime()); return; } +// List<Integer> lines=new ArrayList<>(); +// if(REQUEST_WORD.equals(d03ToMES)){ +// lines.add(Const.A09_OUT_TARGET_POSITION); +// } +// if(REQUEST_WORD.equals(d05ToMES)){ +// lines.add(Const.A10_OUT_TARGET_POSITION); +// } LambdaQueryWrapper<BigStorageCageFeedTask> wrapper = new LambdaQueryWrapper<BigStorageCageFeedTask>() .eq(BigStorageCageFeedTask::getTaskType, Const.BIG_STORAGE_IN_RUN) .and(e -> e.isNull(BigStorageCageFeedTask::getTargetSlot).or().eq(BigStorageCageFeedTask::getTargetSlot, Const.OUT_TARGET_POSITION_ZERO)) .eq(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_UP); +// .in(BigStorageCageFeedTask::getLine,lines); //鑾峰彇鍙互鍚姩鍗ц浆绔嬬殑浠诲姟绾胯矾 List<BigStorageCageFeedTask> feedTaskList = bigStorageCageFeedTaskService.list(wrapper); if (CollectionUtils.isNotEmpty(feedTaskList)) { @@ -179,11 +268,6 @@ String d01Id = plcParameterObject.getPlcParameter("D01ID").getValue(); String d04Id = plcParameterObject.getPlcParameter("D04ID").getValue(); log.info("1銆佽幏鍙杁01Id鎵弿ID涓猴細{};鑾峰彇d04Id鎵弿ID涓猴細{};", d01Id, d04Id); - //涓ゆ潯绾块兘鏈夎繘鍗ц浆绔嬩换鍔★紝鐩存帴缁撴潫 -// if (StringUtils.isNotBlank(d01Id) && StringUtils.isNotBlank(d04Id)) { -// log.info("涓ゆ潯绾块兘瀛樺湪杩涚墖浠诲姟锛岀粨鏉熶换鍔�"); -// return; -// } //鑾峰彇涓ゆ潯绾垮崸杞珛鏄惁鏈夌幓鐠冿紝涓斾换鍔$姸鎬佷负1/2 List<Integer> lineList = bigStorageCageFeedTaskService.querySitToUpGlass(); if (CollectionUtils.isEmpty(lineList)) { @@ -203,6 +287,8 @@ //鑾峰彇鍗ц浆绔嬪墿浣欏搴� if (computeIsRun(lineFirst, lineGlassId)) { computeTargetByLine(lineFirst); + } else { + log.info("褰撳墠绾胯矾锛歿}锛屾湁鎵爜鐜荤拑锛歿}", lineFirst, lineGlassId); } } Date endDate = new Date(); @@ -212,7 +298,8 @@ //涓ゆ潯鍏堝潎鍙墽琛岃繘鐗囦换鍔★紝鍒ゆ柇涓ゆ潯绾挎槸鍚﹁繘鐗囪姹傛槸鍚﹂兘涓虹┖ if (StringUtils.isBlank(d01Id) && StringUtils.isBlank(d04Id)) { //姣旇緝鏈�鏃╀竴鐗囦换鍔$殑鐗堝浘id鍙婄増搴� 姹傚嚭鍗ц浆绔嬬殑绾胯矾 - Integer line = getStartLine(); +// Integer line = getStartLine(); + Integer line = lineList.get(0); //璁$畻浠诲姟琛ㄨ繘鐗囨牸瀛� 鍙戦�佽繘鐗囦换鍔� computeTargetByLine(line); Date endDate = new Date(); @@ -242,101 +329,160 @@ computeTargetByLine(outLine); } Date endDate = new Date(); + log.info("澶х悊鐗囩绌鸿溅杩涚墖浠诲姟缁撴潫鏃堕棿锛歿}锛屽叡鑰楁椂锛歿}ms,缁撴潫鎵爜浠诲姟", endDate, endDate.getTime() - startDate.getTime()); } - @Scheduled(fixedDelay = 300) + @Scheduled(fixedDelay = 5000) public void plcToHomeEdgOutTask() { Date startDate = new Date(); - log.info("澶х悊鐗囩绌鸿溅杩涚墖浠诲姟寮�濮嬫墽琛屾椂闂达細{}", startDate); + log.info("澶х悊鐗囩鍑虹墖浠诲姟寮�濮嬫墽琛屾椂闂达細{}", startDate); PlcParameterObject plcMesObject = S7object.getinstance().PlcMesObject; - String e02State = plcMesObject.getPlcParameter("E02State").getAddress(); + String e02State = plcMesObject.getPlcParameter("E02State").getValue(); if (REQUEST_WORD.equals(e02State)) { log.info("鍑虹墖蹇欑锛岀粨鏉熷嚭鐗囦换鍔�"); return; } String mesToPLCAddress = plcMesObject.getPlcParameter("MESToPLC").getAddress(); - List<BigStorageCageOutTask> outingList = bigStorageCageOutTaskService.list(new LambdaQueryWrapper<BigStorageCageOutTask>().eq(BigStorageCageOutTask::getTaskState, Const.BIG_STORAGE_OUT_NEW)); - Assert.isTrue(CollectionUtils.isEmpty(outingList), "鏈夋鍦ㄦ墽琛屽嚭鐗囩殑浠诲姟锛岀粨鏉熷綋鍓嶅嚭鐗囩嚎绋�"); - - //鏄惁鏈夋鍦ㄩ挗鍖栫殑鐜荤拑 - List<TemperingGlassInfo> temperingGlassInfoList = temperingGlassInfoService.selectJoinList(TemperingGlassInfo.class, new MPJLambdaWrapper<TemperingGlassInfo>() - .selectAll(TemperingGlassInfo.class) - .leftJoin(BigStorageCageOutTask.class, BigStorageCageOutTask::getGlassId, TemperingGlassInfo::getGlassId) - .eq(TemperingGlassInfo::getState, Const.TEMPERING_NEW) - .isNull(BigStorageCageOutTask::getGlassId) - .orderBy(Boolean.TRUE, sequenceOrder, TemperingGlassInfo::getTemperingFeedSequence)); - if (CollectionUtils.isNotEmpty(temperingGlassInfoList)) { - log.info("鏈夋鍦ㄥ嚭鐗囩殑閽㈠寲浠诲姟"); - computeOutGlassInfo(temperingGlassInfoList, Boolean.TRUE, mesToPLCAddress); - Date endDate = new Date(); - log.info("澶х悊鐗囩鍑虹墖浠诲姟缁撴潫鏃堕棿锛歿}锛屽叡鑰楁椂锛歿}ms,缁撴潫鎵爜浠诲姟", endDate, endDate.getTime() - startDate.getTime()); + List<BigStorageCageOutTask> outingList = bigStorageCageOutTaskService.list(new LambdaQueryWrapper<BigStorageCageOutTask>() + .eq(BigStorageCageOutTask::getTaskState, Const.BIG_STORAGE_OUT_NEW)); + if (CollectionUtils.isNotEmpty(outingList)) { + log.info("鏈夋鍦ㄦ墽琛屽嚭鐗囩殑浠诲姟锛岀粨鏉熷綋鍓嶅嚭鐗囩嚎绋�"); return; } - //鏄惁鏈変汉宸ヤ笅鐗囦换鍔� 鏈夌洿鎺ュ嚭 - List<BigStorageCageDetails> artificialList = bigStorageCageDetailsService.list(new LambdaQueryWrapper<BigStorageCageDetails>() - .eq(BigStorageCageDetails::getState, Const.GLASS_STATE_ARTIFICIAL).orderByDesc(BigStorageCageDetails::getWidth)); - if (CollectionUtils.isNotEmpty(artificialList)) { - computeOutGlassInfo(artificialList, Boolean.FALSE, mesToPLCAddress); - Date endDate = new Date(); - log.info("澶х悊鐗囩鍑虹墖浠诲姟缁撴潫鏃堕棿锛歿}锛屽叡鑰楁椂锛歿}ms,缁撴潫鎵爜浠诲姟", endDate, endDate.getTime() - startDate.getTime()); - return; - } - //閽㈠寲浼樺厛锛氳幏鍙栫悊鐗囩 鐜荤拑灏忕墖 鐮存崯琛� 鏁伴噺 鍒ゆ柇绗煎唴鐗堝浘鏄惁鍒伴綈 - List<TemperingLayoutDTO> temperingLayoutDTOList = bigStorageCageDetailsService.temperingIsAll(); - if (CollectionUtils.isNotEmpty(temperingLayoutDTOList)) { - //鐜荤拑鍒伴綈鍖呮嫭宸插嚭鐗囩殑 - //鍒伴綈锛屽皢鐜荤拑灏忕墖鏁版嵁瀛樺叆閽㈠寲灏忕墖琛紝閫昏緫鐢熸垚鍑虹墖浠诲姟 缁撴潫 - for (TemperingLayoutDTO item : temperingLayoutDTOList) { - List<TemperingGlassInfo> temperingGlassInfos = glassInfoService.selectJoinList(TemperingGlassInfo.class, JoinWrappers.lambda(GlassInfo.class) - .selectAll(GlassInfo.class) - .select("-1 as state") - .selectAs(BigStorageCageDetails::getSlot, TemperingGlassInfo::getSlot) - .innerJoin(BigStorageCageDetails.class, BigStorageCageDetails::getGlassId, GlassInfo::getGlassId) - .eq(BigStorageCageDetails::getState, Const.GLASS_STATE_IN) - .eq(GlassInfo::getTemperingLayoutId, item.getTemperingLayoutId()) - .eq(GlassInfo::getEngineerId, item.getEngineerId()) - .orderBy(Boolean.TRUE, sequenceOrder, GlassInfo::getTemperingFeedSequence)); - if (CollectionUtils.isNotEmpty(temperingGlassInfos)) { - temperingGlassInfoService.saveBatch(temperingGlassInfos); - computeOutGlassInfo(temperingGlassInfoList, Boolean.TRUE, mesToPLCAddress); - Date endDate = new Date(); - log.info("澶х悊鐗囩鍑虹墖浠诲姟缁撴潫鏃堕棿锛歿}锛屽叡鑰楁椂锛歿}ms,缁撴潫鎵爜浠诲姟", endDate, endDate.getTime() - startDate.getTime()); - return; - } + if (redisUtil.getCacheObject("temperingSwitch")) { +// if(true){ + //鏄惁鏈夋鍦ㄩ挗鍖栫殑鐜荤拑 + List<TemperingGlassInfo> temperingGlassInfoList = temperingGlassInfoService.selectJoinList(TemperingGlassInfo.class, new MPJLambdaWrapper<TemperingGlassInfo>() + .selectAll(TemperingGlassInfo.class) + .leftJoin(BigStorageCageOutTask.class, on -> on + .eq(TemperingGlassInfo::getGlassId, BigStorageCageOutTask::getGlassId) + .ne(BigStorageCageOutTask::getTaskState, Const.BIG_STORAGE_OUT_SUCCESS)) + .eq(TemperingGlassInfo::getState, Const.TEMPERING_NEW) + .isNull(BigStorageCageOutTask::getGlassId) + .orderBy(Boolean.TRUE, sequenceOrder, TemperingGlassInfo::getTemperingFeedSequence)); + log.info("鏌ヨ鐨勫嚭鐗囦换鍔★細{}", temperingGlassInfoList); + if (CollectionUtils.isNotEmpty(temperingGlassInfoList)) { + log.info("鏈夋鍦ㄥ嚭鐗囩殑閽㈠寲浠诲姟"); + computeOutMoreGlassInfo(temperingGlassInfoList, Boolean.TRUE, 1); + Date endDate = new Date(); + log.info("澶х悊鐗囩鍑虹墖浠诲姟缁撴潫鏃堕棿锛歿}锛屽叡鑰楁椂锛歿}ms,缁撴潫鎵爜浠诲姟", endDate, endDate.getTime() - startDate.getTime()); + return; } - } - //鏈埌榻� 鎵ц鍐呴儴璋冨害浠诲姟 - TemperingLayoutDTO temperingOccupySlot = bigStorageCageDetailsService.queryTemperingOccupySlot(); - if (null != temperingOccupySlot) { - List<SlotSequenceDTO> slotSequenceList = bigStorageCageDetailsService.queryGlassMaxAndMin(temperingOccupySlot.getEngineerId(), temperingOccupySlot.getTemperingLayoutId()); - for (int i = 0; i < slotSequenceList.size() - 1; i++) { - SlotSequenceDTO first = slotSequenceList.get(i); - SlotSequenceDTO second = slotSequenceList.get(i + 1); - int slotWidth = carWidth - first.getRemainWidth() - glassGap; - if (first.getMinSequence() == second.getMaxSequence() + 1 - && second.getRemainWidth() > slotWidth) { - List<BigStorageCageDetails> list = bigStorageCageDetailsService.list(new LambdaQueryWrapper<BigStorageCageDetails>() - .eq(BigStorageCageDetails::getSlot, first.getSlot()).eq(BigStorageCageDetails::getState, Const.GLASS_STATE_IN)); - List<BigStorageCageOutTask> outTasks = list.stream().map(e -> new BigStorageCageOutTask(e.getGlassId(), first.getSlot(), second.getSlot(), - e.getWidth() * 10, e.getHeight() * 10, 0, 0, 1)).collect(Collectors.toList()); - bigStorageCageOutTaskService.saveBatch(outTasks); - - //鍚憄lc鍐欏叆纭瀛� - int returnData = 0; - int count = 1; - while (returnData == 0) { - log.info("宸插悜plc绗瑊}娆¢�佸崗璁�", count); - S7object.getinstance().plccontrol.writeWord(mesToPLCAddress, 1); - returnData = S7object.getinstance().plccontrol.readWord(mesToPLCAddress, 1).get(0); - log.info("宸插悜plc绗瑊}娆″彂閫佸嚭鐗囦换鍔$‘璁わ紝鍦板潃涓猴細{},鍐欏叆鐨勫唴瀹逛负{}", count++, mesToPLCAddress, returnData); + //鏄惁鏈変汉宸ヤ笅鐗囦换鍔� 鏈夌洿鎺ュ嚭 +// List<BigStorageCageDetails> artificialList = bigStorageCageDetailsService.list(new LambdaQueryWrapper<BigStorageCageDetails>() +// .eq(BigStorageCageDetails::getState, Const.GLASS_STATE_ARTIFICIAL).orderByDesc(BigStorageCageDetails::getWidth)); + List<BigStorageCageDetails> artificialList = bigStorageCageDetailsService.list(new LambdaQueryWrapper<BigStorageCageDetails>() + .eq(BigStorageCageDetails::getState, Const.GLASS_STATE_ARTIFICIAL) + .orderByAsc(BigStorageCageDetails::getSlot) + .orderByDesc(BigStorageCageDetails::getId)); + if (CollectionUtils.isNotEmpty(artificialList)) { + computeOutMoreGlassInfo(artificialList, Boolean.FALSE, 1); + Date endDate = new Date(); + log.info("澶х悊鐗囩鍑虹墖浠诲姟缁撴潫鏃堕棿锛歿}锛屽叡鑰楁椂锛歿}ms,缁撴潫鎵爜浠诲姟", endDate, endDate.getTime() - startDate.getTime()); + return; + } + //閽㈠寲浼樺厛锛氳幏鍙栫悊鐗囩 鐜荤拑灏忕墖 鐮存崯琛� 鏁伴噺 鍒ゆ柇绗煎唴鐗堝浘鏄惁鍒伴綈 + List<TemperingLayoutDTO> temperingLayoutDTOList = bigStorageCageDetailsService.temperingIsAll(); + if (CollectionUtils.isNotEmpty(temperingLayoutDTOList)) { + //鐜荤拑鍒伴綈鍖呮嫭宸插嚭鐗囩殑 + //鍒伴綈锛屽皢鐜荤拑灏忕墖鏁版嵁瀛樺叆閽㈠寲灏忕墖琛紝閫昏緫鐢熸垚鍑虹墖浠诲姟 缁撴潫 + for (TemperingLayoutDTO item : temperingLayoutDTOList) { + if (redisUtil.getCacheObject("temperingengineerId").equals(item.getEngineerId())) { + List<TemperingGlassInfo> temperingGlassInfos = glassInfoService.selectJoinList(TemperingGlassInfo.class, JoinWrappers.lambda(GlassInfo.class) + .selectAll(GlassInfo.class) + .select("-1 as state") + .selectAs(BigStorageCageDetails::getSlot, TemperingGlassInfo::getSlot) + .innerJoin(BigStorageCageDetails.class, BigStorageCageDetails::getGlassId, GlassInfo::getGlassId) + .eq(BigStorageCageDetails::getState, Const.GLASS_STATE_IN) + .eq(GlassInfo::getTemperingLayoutId, item.getTemperingLayoutId()) + .eq(GlassInfo::getEngineerId, item.getEngineerId()) + .orderBy(Boolean.TRUE, sequenceOrder, GlassInfo::getTemperingFeedSequence)); + if (CollectionUtils.isNotEmpty(temperingGlassInfos)) { + temperingGlassInfoService.saveBatch(temperingGlassInfos); + computeOutMoreGlassInfo(temperingGlassInfoList, Boolean.TRUE, 1); + Date endDate = new Date(); + log.info("澶х悊鐗囩鍑虹墖浠诲姟缁撴潫鏃堕棿锛歿}锛屽叡鑰楁椂锛歿}ms,缁撴潫鎵爜浠诲姟", endDate, endDate.getTime() - startDate.getTime()); + return; + } } - Date endDate = new Date(); - log.info("澶х悊鐗囩鍑虹墖浠诲姟缁撴潫鏃堕棿锛歿}锛屽叡鑰楁椂锛歿}ms,缁撴潫鎵爜浠诲姟", endDate, endDate.getTime() - startDate.getTime()); - return; } } + } else { + //鎵ц鍐呴儴璋冨害浠诲姟 + List<TemperingLayoutDTO> temperingOccupySlotList = bigStorageCageDetailsService.queryTemperingOccupySlot(); + if (CollectionUtils.isNotEmpty(temperingOccupySlotList)) { + loop: + for (TemperingLayoutDTO temperingOccupySlot : temperingOccupySlotList) { + List<GlassInfo> glassInfos = glassInfoService.list( + new LambdaQueryWrapper<GlassInfo>() + .eq(GlassInfo::getEngineerId, temperingOccupySlot.getEngineerId()) + .eq(GlassInfo::getTemperingLayoutId, temperingOccupySlot.getTemperingLayoutId()) + .notInSql(GlassInfo::getGlassId, "select glass_id from damage where type=8 and engineer_id='" + + temperingOccupySlot.getEngineerId() + "' and tempering_layout_id = '" + temperingOccupySlot.getTemperingLayoutId() + "'") + .orderBy(Boolean.TRUE, sequenceOrder, GlassInfo::getTemperingFeedSequence) + ); + Map<Integer, List<GlassInfo>> listMap = glassInfos.stream().collect(Collectors.groupingBy(item -> item.getTargetSlot())); + for (Map.Entry<Integer, List<GlassInfo>> entry : listMap.entrySet()) { + List<GlassInfo> valueList = entry.getValue(); + List<String> glassIds = valueList.stream().map(GlassInfo::getGlassId).collect(Collectors.toList()); + List<BigStorageCageDetails> bigStorageCageDetailsList = bigStorageCageDetailsService.list( + new LambdaQueryWrapper<BigStorageCageDetails>() + .in(BigStorageCageDetails::getGlassId, glassIds) + .eq(BigStorageCageDetails::getState, Const.GLASS_STATE_IN) + .orderBy(Boolean.TRUE, sequenceOrder, BigStorageCageDetails::getTemperingFeedSequence) + ); + List<BigStorageCageDetails> overSizeGlass = bigStorageCageDetailsList.stream().filter( + t -> Math.min(t.getWidth(), t.getHeight()) > 2500 + ).collect(Collectors.toList()); + if (CollectionUtils.isEmpty(overSizeGlass)) { + //褰撲竴鏍肩幓鐠冮兘鍒伴綈鏃� + if (bigStorageCageDetailsList.size() == valueList.size()) { + long distinctSlotCount = bigStorageCageDetailsList.stream() + .map(BigStorageCageDetails::getSlot) + .distinct() + .count(); + //褰撶幓鐠冧笉鍦ㄥ悓涓�鏍兼椂 + if (distinctSlotCount > 1) { + BigStorageCageDetails maxSequenceDetail = bigStorageCageDetailsList.stream() + .max(Comparator.comparingInt(BigStorageCageDetails::getTemperingFeedSequence)) + .orElse(null); // 濡傛灉娌℃湁鍏冪礌锛岃繑鍥� null + int maxSlot = maxSequenceDetail.getSlot(); + int serialNumber = 1; + for (BigStorageCageDetails bigStorageCageDetails : bigStorageCageDetailsList + ) { + if (bigStorageCageDetails.getSlot() != maxSlot) { + bigStorageCageOutTaskService.save(new BigStorageCageOutTask(bigStorageCageDetails.getGlassId(), bigStorageCageDetails.getSlot(), maxSlot, + bigStorageCageDetails.getWidth() * 10, bigStorageCageDetails.getHeight() * 10, 1, serialNumber++, Const.BIG_STORAGE_OUT_NEW, new Date())); + + bigStorageCageDetailsService.update(new LambdaUpdateWrapper<BigStorageCageDetails>().set(BigStorageCageDetails::getState, Const.GLASS_STATE_SCHEDULE_ING) + .set(BigStorageCageBaseInfo::getSlot, maxSlot).eq(BigStorageCageDetails::getGlassId, bigStorageCageDetails.getGlassId()) + .ne(BigStorageCageDetails::getState, Const.GLASS_STATE_OUT)); + //涓ゆ鏇存柊绗煎瓙鐨勫墿浣欏昂瀵革細绗竴娆¢槻姝㈡湁鐜荤拑缁х画杩涜皟搴﹀悗鐨勭瀛愶紝绗簩娆℃洿鏂帮細璁$畻鏍煎瓙鐨勫疄闄呭昂瀵� + // 浠呮洿鏂拌皟搴﹀悗鐨勬牸瀛愪俊鎭細璧峰鏍煎瓙瀹屾垚鍚庢洿鏂帮細闃叉璋冨害鍑虹墖杩囩▼涓湁鏂扮幓鐠冭繘鍏ワ紝 + } + } + break loop; + } + } + } + } + } +// //鍚憄lc鍐欏叆纭瀛� +// int returnData = 0; +// int count = 1; +// while (returnData == 0) { +// log.info("宸插悜plc绗瑊}娆¢�佸崗璁�", count); +// S7object.getinstance().plccontrol.writeWord(mesToPLCAddress, 1); +// returnData = S7object.getinstance().plccontrol.readWord(mesToPLCAddress, 1).get(0); +// log.info("宸插悜plc绗瑊}娆″彂閫佸嚭鐗囦换鍔$‘璁わ紝鍦板潃涓猴細{},鍐欏叆鐨勫唴瀹逛负{}", count++, mesToPLCAddress, returnData); +// } + Date endDate = new Date(); + log.info("澶х悊鐗囩鍑虹墖浠诲姟缁撴潫鏃堕棿锛歿}锛屽叡鑰楁椂锛歿}ms,缁撴潫鎵爜浠诲姟", endDate, endDate.getTime() - startDate.getTime()); + return; + } } + } @Scheduled(fixedDelay = 300) @@ -354,16 +500,16 @@ .in(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_SLOT)); if (CollectionUtils.isNotEmpty(inSuccessGlass)) { log.info("3銆佽幏鍙栬繘鐗囧凡瀹屾垚鐨勭幓鐠冧俊鎭痠d:{}", inSuccessGlass); - List<String> inSuccessGlassIds = inSuccessGlass.stream().map(BigStorageCageFeedTask::getGlassId).collect(Collectors.toList()); + List<Integer> inSuccessGlassSlot = inSuccessGlass.stream().map(BigStorageCageFeedTask::getTargetSlot).collect(Collectors.toList()); List<UpdateBigStorageCageDTO> storageCageDTOList = inSuccessGlass.stream().map(e -> { UpdateBigStorageCageDTO storageCageDTO = new UpdateBigStorageCageDTO(); - BeanUtils.copyProperties(inSuccessGlass, storageCageDTO); + BeanUtils.copyProperties(e, storageCageDTO); return storageCageDTO; }).collect(Collectors.toList()); bigStorageCageDetailsService.updateBySlot(storageCageDTOList, Const.GLASS_STATE_IN); - log.info("4銆佸ぇ鐞嗙墖绗艰繘鐗囩姸鎬佸凡瀹屾垚宸插畬鎴愮殑鐜荤拑淇℃伅id:{}", inSuccessGlassIds); + log.info("4銆佸ぇ鐞嗙墖绗艰繘鐗囩姸鎬佸凡瀹屾垚宸插畬鎴愮殑鐜荤拑淇℃伅id:{}", inSuccessGlass); //鏇存柊鐞嗙墖绗肩幓鐠冨昂瀵� - updateSlotRemain(inSuccessGlassIds, Boolean.TRUE); + updateSlotRemainBySlots(inSuccessGlassSlot); log.info("5銆佸ぇ鐞嗙墖绗艰繘鐗囩洰鏍囨牸瀛愬昂瀵告洿鏂板畬鎴�"); } @@ -380,24 +526,73 @@ log.info("1銆佸ぇ鐞嗙墖绗煎嚭鐗囧畬鎴愬悗鏇存柊澶х悊鐗囩鏁版嵁浠诲姟寮�濮嬫墽琛屾椂闂达細{}", startDate); //鍥犱负澶х悊鐗囩鍜屽嚭鐗囦换鍔℃槸涓や釜搴撶殑鏁版嵁锛屾墍浠ヨ鍒嗗紑鏌ユ壘 List<Object> list = bigStorageCageDetailsService.listObjs(new LambdaQueryWrapper<BigStorageCageDetails>() - .select(BigStorageCageDetails::getGlassId).eq(BigStorageCageDetails::getState, Const.GLASS_STATE_OUT_ING)); + .select(BigStorageCageDetails::getGlassId) + .in(BigStorageCageDetails::getState, Const.GLASS_STATE_OUT_ING)); if (CollectionUtils.isNotEmpty(list)) { log.info("2銆佽幏鍙栨墍鏈夋鍦ㄥ嚭鐗囩殑鐜荤拑淇℃伅id:{}", list); List<String> glassIds = list.stream().map(String::valueOf).collect(Collectors.toList()); List<BigStorageCageOutTask> outSuccessGlass = bigStorageCageOutTaskService.list(new LambdaQueryWrapper<BigStorageCageOutTask>() - .select(BigStorageCageOutTask::getGlassId).in(BigStorageCageOutTask::getGlassId, glassIds).in(BigStorageCageOutTask::getTaskState, Const.BIG_STORAGE_OUT_ALL)); + .in(BigStorageCageOutTask::getGlassId, glassIds).in(BigStorageCageOutTask::getTaskState, Const.BIG_STORAGE_OUT_ALL)); if (CollectionUtils.isNotEmpty(outSuccessGlass)) { + for (BigStorageCageOutTask bigStorageCageOutTask : outSuccessGlass + ) { + if (bigStorageCageOutTask.getEndSlot().equals(Const.ARTIFICIAL_OUT_TARGET_POSITION)) { + temperingGlassInfoService.update( + new LambdaUpdateWrapper<TemperingGlassInfo>() + .set(TemperingGlassInfo::getState, Const.TEMPERING_END) + .eq(TemperingGlassInfo::getGlassId, bigStorageCageOutTask.getGlassId()) + ); + } + } log.info("3銆佽幏鍙栧嚭鐗囧凡瀹屾垚鐨勭幓鐠冧俊鎭痠d:{}", outSuccessGlass); List<UpdateBigStorageCageDTO> storageCageDTOList = outSuccessGlass.stream().map(e -> { UpdateBigStorageCageDTO storageCageDTO = new UpdateBigStorageCageDTO(); - BeanUtils.copyProperties(outSuccessGlass, storageCageDTO); + storageCageDTO.setGlassId(e.getGlassId()); + storageCageDTO.setTargetSlot(e.getStartSlot()); return storageCageDTO; }).collect(Collectors.toList()); bigStorageCageDetailsService.updateBySlot(storageCageDTOList, Const.GLASS_STATE_OUT); - List<String> outSuccessGlassIds = outSuccessGlass.stream().map(BigStorageCageOutTask::getGlassId).collect(Collectors.toList()); - log.info("4銆佸ぇ鐞嗙墖绗煎嚭鐗囩姸鎬佸凡瀹屾垚宸插畬鎴愮殑鐜荤拑淇℃伅id:{}", outSuccessGlassIds); + List<Integer> outSuccessSlotList = outSuccessGlass.stream().map(BigStorageCageOutTask::getStartSlot).collect(Collectors.toList()); + log.info("4銆佸ぇ鐞嗙墖绗煎嚭鐗囩姸鎬佸凡瀹屾垚宸插畬鎴愮殑鐜荤拑淇℃伅id:{}", outSuccessGlass); //鏇存柊鐞嗙墖绗肩幓鐠冨昂瀵� - updateSlotRemain(outSuccessGlassIds, Boolean.FALSE); + updateSlotRemainBySlots(outSuccessSlotList); + log.info("5銆佸ぇ鐞嗙墖绗艰繘鐗囩洰鏍囨牸瀛愬昂瀵告洿鏂板畬鎴�"); + } + } + Date endDate = new Date(); + log.info("end:澶х悊鐗囩鍑虹墖瀹屾垚鍚庢洿鏂板ぇ鐞嗙墖绗兼暟鎹换鍔$粨鏉熸椂闂达細{}锛屽叡鑰楁椂锛歿}ms,缁撴潫浠诲姟", endDate, endDate.getTime() - startDate.getTime()); + return; + + } + + @Scheduled(fixedDelay = 300) + public void updateScheduleGlassStateTask() { + Date startDate = new Date(); + log.info("1銆佸ぇ鐞嗙墖绗艰皟搴﹀畬鎴愬悗鏇存柊澶х悊鐗囩鏁版嵁浠诲姟寮�濮嬫墽琛屾椂闂达細{}", startDate); + //鍥犱负澶х悊鐗囩鍜岃皟搴︿换鍔℃槸涓や釜搴撶殑鏁版嵁锛屾墍浠ヨ鍒嗗紑鏌ユ壘 + List<Object> list = bigStorageCageDetailsService.listObjs(new LambdaQueryWrapper<BigStorageCageDetails>() + .select(BigStorageCageDetails::getGlassId).eq(BigStorageCageDetails::getState, Const.GLASS_STATE_SCHEDULE_ING)); + if (CollectionUtils.isNotEmpty(list)) { + log.info("2銆佽幏鍙栨墍鏈夋鍦ㄥ嚭鐗囩殑鐜荤拑淇℃伅id:{}", list); + List<String> glassIds = list.stream().map(String::valueOf).collect(Collectors.toList()); + List<BigStorageCageOutTask> scheduleSuccessGlass = bigStorageCageOutTaskService.list(new LambdaQueryWrapper<BigStorageCageOutTask>() + .in(BigStorageCageOutTask::getGlassId, glassIds).eq(BigStorageCageOutTask::getTaskState, Const.BIG_STORAGE_OUT_SUCCESS) + .notIn(BigStorageCageOutTask::getEndSlot, Const.TEMPERING_OUT_TARGET_POSITION, Const.ARTIFICIAL_OUT_TARGET_POSITION)); + if (CollectionUtils.isNotEmpty(scheduleSuccessGlass)) { + log.info("3銆佽幏鍙栬皟搴﹀凡瀹屾垚鐨勭幓鐠冧俊鎭痠d:{}", scheduleSuccessGlass); + List<UpdateBigStorageCageDTO> storageCageDTOList = scheduleSuccessGlass.stream().map(e -> { + UpdateBigStorageCageDTO storageCageDTO = new UpdateBigStorageCageDTO(); + storageCageDTO.setGlassId(e.getGlassId()); + storageCageDTO.setTargetSlot(e.getEndSlot()); + return storageCageDTO; + }).collect(Collectors.toList()); + bigStorageCageDetailsService.updateBySlot(storageCageDTOList, Const.GLASS_STATE_IN); + List<String> scheduleSuccessGlassIds = scheduleSuccessGlass.stream().map(BigStorageCageOutTask::getGlassId).collect(Collectors.toList()); + log.info("4銆佸ぇ鐞嗙墖绗煎嚭鐗囩姸鎬佸凡瀹屾垚宸插畬鎴愮殑鐜荤拑淇℃伅id:{}", scheduleSuccessGlassIds); + //鏇存柊鐞嗙墖绗肩幓鐠冨昂瀵� + List<Integer> slotList = scheduleSuccessGlass.stream().map(BigStorageCageOutTask::getStartSlot).distinct().collect(Collectors.toList()); + slotList.addAll(scheduleSuccessGlass.stream().map(BigStorageCageOutTask::getEndSlot).distinct().collect(Collectors.toList())); + updateSlotRemainBySlots(slotList); log.info("5銆佸ぇ鐞嗙墖绗艰繘鐗囩洰鏍囨牸瀛愬昂瀵告洿鏂板畬鎴�"); } } @@ -416,48 +611,59 @@ log.info("澶х悊鐗囩鐮存崯鐜荤拑娓呴櫎浠诲姟寮�濮嬫墽琛屾椂闂达細{}", startDate); //鑾峰彇杩涚墖浠诲姟琛ㄤ腑鐘舵�佷负鐮存崯鐨勬暟鎹� List<BigStorageCageFeedTask> inDamageTaskInfoList = bigStorageCageFeedTaskService.list(new LambdaQueryWrapper<BigStorageCageFeedTask>() - .eq(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_DAMAGE)); + .in(BigStorageCageFeedTask::getTaskState, Const.GLASS_STATE_DAMAGE_TAKE)); if (CollectionUtils.isNotEmpty(inDamageTaskInfoList)) { log.info("鑾峰彇杩涚墖浠诲姟琛ㄤ腑鐮存崯鐨勭幓鐠冧俊鎭瘂}", inDamageTaskInfoList); - bigStorageCageFeedTaskService.remove(new LambdaQueryWrapper<BigStorageCageFeedTask>().eq(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_DAMAGE)); + bigStorageCageFeedTaskService.remove(new LambdaQueryWrapper<BigStorageCageFeedTask>().in(BigStorageCageFeedTask::getTaskState, Const.GLASS_STATE_DAMAGE_TAKE)); //鐞嗙墖绗艰鎯呰〃鏁版嵁鐘舵�佹洿鏂� - bigStorageCageDetailsService.update(new LambdaUpdateWrapper<BigStorageCageDetails>() - .set(BigStorageCageDetails::getState, Const.GLASS_STATE_DAMAGE).in(BigStorageCageDetails::getGlassId, inDamageTaskInfoList.stream().map(BigStorageCageFeedTask::getGlassId).collect(Collectors.toList()))); + bigStorageCageDetailsService.remove(new LambdaQueryWrapper<BigStorageCageDetails>() +// .eq(BigStorageCageDetails::getState, Const.GLASS_STATE_NEW) + .and(e -> e.eq(BigStorageCageDetails::getState, Const.GLASS_STATE_NEW).or() + .eq(BigStorageCageDetails::getState, Const.GLASS_STATE_IN)) + .in(BigStorageCageDetails::getGlassId, inDamageTaskInfoList.stream().map(BigStorageCageFeedTask::getGlassId).collect(Collectors.toList()))); //灏嗙牬鎹熶俊鎭柊澧炲叆鐮存崯琛� + List<Integer> slotList = new ArrayList<>(); for (BigStorageCageFeedTask bigStorageCageFeedTask : inDamageTaskInfoList) { Damage damage = new Damage(); damage.setGlassId(bigStorageCageFeedTask.getGlassId()); damage.setLine(bigStorageCageFeedTask.getLine()); - damage.setWorkingProcedure("鍐峰姞宸�"); + damage.setWorkingProcedure("閽㈠寲"); damage.setRemark("杩涚鍓嶅崸杞珛"); - damage.setStatus(2); + damage.setStatus(1); + damage.setType(bigStorageCageFeedTask.getTaskState()); damageService.insertDamage(damage); + slotList.add(bigStorageCageFeedTask.getTargetSlot()); } + //鏇存柊鏍煎瓙鍓╀綑瀹藉害 + updateSlotRemainBySlots(slotList); log.info("杩涚墖浠诲姟鎵ц瀹屾垚"); } //鑾峰彇鍑虹墖浠诲姟琛ㄤ腑鐘舵�佷负鐮存崯鐨勬暟鎹� List<BigStorageCageOutTask> outDamageTaskInfoList = bigStorageCageOutTaskService.list(new LambdaQueryWrapper<BigStorageCageOutTask>() - .eq(BigStorageCageOutTask::getTaskState, Const.BIG_STORAGE_OUT_DAMAGE)); + .in(BigStorageCageOutTask::getTaskState, Const.GLASS_STATE_DAMAGE_TAKE)); if (CollectionUtils.isNotEmpty(outDamageTaskInfoList)) { log.info("鑾峰彇鍑虹墖浠诲姟琛ㄤ腑鐮存崯鐨勭幓鐠冧俊鎭瘂}", outDamageTaskInfoList); - bigStorageCageOutTaskService.remove(new LambdaQueryWrapper<BigStorageCageOutTask>().eq(BigStorageCageOutTask::getTaskState, Const.BIG_STORAGE_IN_DAMAGE)); + bigStorageCageOutTaskService.remove(new LambdaQueryWrapper<BigStorageCageOutTask>().in(BigStorageCageOutTask::getTaskState, Const.GLASS_STATE_DAMAGE_TAKE)); List<String> glassIdList = outDamageTaskInfoList.stream().map(BigStorageCageOutTask::getGlassId).collect(Collectors.toList()); //绉婚櫎閽㈠寲涓嬬墖琛ㄦ暟鎹� temperingGlassInfoService.remove(new LambdaQueryWrapper<TemperingGlassInfo>().in(TemperingGlassInfo::getGlassId, glassIdList)); - //鐞嗙墖绗艰鎯呰〃鏁版嵁鐘舵�佹洿鏂� - bigStorageCageDetailsService.update(new LambdaUpdateWrapper<BigStorageCageDetails>() - .set(BigStorageCageDetails::getState, Const.GLASS_STATE_DAMAGE).in(BigStorageCageDetails::getGlassId, glassIdList)); - + //鐞嗙墖绗艰鎯呰〃鏁版嵁鐘舵�佸垹闄� + bigStorageCageDetailsService.remove(new LambdaQueryWrapper<BigStorageCageDetails>().in(BigStorageCageDetails::getGlassId, glassIdList)); //灏嗙牬鎹熶俊鎭柊澧炲叆鐮存崯琛� + List<Integer> slotList = new ArrayList<>(); for (BigStorageCageOutTask bigStorageCageOutTask : outDamageTaskInfoList) { Damage damage = new Damage(); damage.setGlassId(bigStorageCageOutTask.getGlassId()); damage.setLine(bigStorageCageOutTask.getEndSlot()); - damage.setWorkingProcedure("鍐峰姞宸�"); + damage.setWorkingProcedure("閽㈠寲"); damage.setRemark("鍑虹墖鍚庡崸杞珛"); - damage.setStatus(2); + damage.setStatus(1); + damage.setType(bigStorageCageOutTask.getTaskState()); damageService.insertDamage(damage); + slotList.add(bigStorageCageOutTask.getStartSlot()); } + //鏇存柊鏍煎瓙鍓╀綑瀹藉害 + updateSlotRemainBySlots(slotList); log.info("鍑虹墖浠诲姟鎵ц瀹屾垚"); } Date endDate = new Date(); @@ -466,14 +672,214 @@ } /** + * 纭瀛楁竻绌� + */ + @Scheduled(fixedDelay = 300) + public void confirmClear() { + PlcParameterObject plcParameterObject = S7object.getinstance().PlcMesObject; + String d01ToMES = plcParameterObject.getPlcParameter("D01ToMES").getValue(); + String d04ToMES = plcParameterObject.getPlcParameter("D04ToMES").getValue(); + String mesD01Address = plcParameterObject.getPlcParameter("MESToD01").getAddress(); + String mesD04Address = plcParameterObject.getPlcParameter("MESToD04").getAddress(); +// String d03ToMES = plcParameterObject.getPlcParameter("D03ToMES").getValue(); +// String d05ToMES = plcParameterObject.getPlcParameter("D05ToMES").getValue(); + String d03ToMES = plcParameterObject.getPlcParameter("D03Request").getValue(); + String d05ToMES = plcParameterObject.getPlcParameter("D05Request").getValue(); + String mesD03Address = plcParameterObject.getPlcParameter("MESToD03").getAddress(); + String mesD05Address = plcParameterObject.getPlcParameter("MESToD05").getAddress(); + String carRequest = plcParameterObject.getPlcParameter("CarRequest").getValue(); + String carResponse = plcParameterObject.getPlcParameter("CarResponse").getAddress(); + if (!REQUEST_WORD.equals(d01ToMES)) { + log.info("鍦板潃锛歿}鍐欏叆0", mesD01Address); + S7object.getinstance().plccontrol.writeWord(mesD01Address, 0); + } + if (!REQUEST_WORD.equals(d04ToMES)) { + log.info("鍦板潃锛歿}鍐欏叆0", mesD04Address); + S7object.getinstance().plccontrol.writeWord(mesD04Address, 0); + } + if (!REQUEST_WORD.equals(d03ToMES)) { + log.info("鍦板潃锛歿}鍐欏叆0", mesD03Address); + S7object.getinstance().plccontrol.writeWord(mesD03Address, 0); + } + if (!REQUEST_WORD.equals(d05ToMES)) { + log.info("鍦板潃锛歿}鍐欏叆0", mesD05Address); + S7object.getinstance().plccontrol.writeWord(mesD05Address, 0); + } + if (!REQUEST_WORD.equals(carRequest)) { + log.info("鍦板潃锛歿}鍐欏叆0", carResponse); + S7object.getinstance().plccontrol.writeWord(carResponse, 0); + } + } + + + /** + * 杩涚墖鐘舵�佷慨鏀� + */ + @Scheduled(fixedDelay = 300) + public void feedStatusUpdate() { + PlcParameterObject plcParameterObject = S7object.getinstance().PlcMesObject; + String mesD03Address = plcParameterObject.getPlcParameter("MESToD03").getAddress(); + String mesD05Address = plcParameterObject.getPlcParameter("MESToD05").getAddress(); + List<String> glassIds1 = new ArrayList<>(); + List<String> glassIds2 = new ArrayList<>(); + List<String> glassIdsCar = new ArrayList<>(); + for (int i = 1; i <= 6; i++) { + String line1GlassId = plcParameterObject.getPlcParameter("D03ID" + i).getValue(); + if (StringUtils.isNotEmpty(line1GlassId)) { + glassIds1.add(line1GlassId); + } + String line2GlassId = plcParameterObject.getPlcParameter("D05ID" + i).getValue(); + if (StringUtils.isNotEmpty(line2GlassId)) { + glassIds2.add(line2GlassId); + } + String carGlassId = plcParameterObject.getPlcParameter("E01ID" + i).getValue(); + if (StringUtils.isNotEmpty(carGlassId)) { + glassIdsCar.add(carGlassId); + } + } + List<BigStorageCageFeedTask> bigStorageCageFeedTasks1 = bigStorageCageFeedTaskService.list( + new LambdaQueryWrapper<BigStorageCageFeedTask>() + .eq(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_NEW) + .eq(BigStorageCageFeedTask::getLine, Const.A09_OUT_TARGET_POSITION) + ); + List<BigStorageCageFeedTask> bigStorageCageFeedTasks2 = bigStorageCageFeedTaskService.list( + new LambdaQueryWrapper<BigStorageCageFeedTask>() + .eq(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_NEW) + .eq(BigStorageCageFeedTask::getLine, Const.A10_OUT_TARGET_POSITION) + ); + if (CollectionUtils.isNotEmpty(bigStorageCageFeedTasks1) && CollectionUtils.isNotEmpty(glassIds1)) { + List<String> matchingIds1 = bigStorageCageFeedTasks1.stream() + .map(BigStorageCageFeedTask::getGlassId) + .filter(glassIds1::contains) + .distinct() + .collect(Collectors.toList()); + log.info("D3id{},鍖归厤id:{}", glassIds1, matchingIds1); + if (CollectionUtils.isNotEmpty(matchingIds1)) { + bigStorageCageFeedTaskService.update( + new LambdaUpdateWrapper<BigStorageCageFeedTask>() + .in(BigStorageCageFeedTask::getGlassId, matchingIds1) + .lt(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_SLOT) + .set(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_UP) + ); + } + } + if (CollectionUtils.isNotEmpty(bigStorageCageFeedTasks2) && CollectionUtils.isNotEmpty(glassIds2)) { + List<String> matchingIds2 = bigStorageCageFeedTasks2.stream() + .map(BigStorageCageFeedTask::getGlassId) + .filter(glassIds2::contains) + .distinct() + .collect(Collectors.toList()); + log.info("D5id{},鍖归厤id:{}", glassIds2, matchingIds2); + if (CollectionUtils.isNotEmpty(matchingIds2)) { + bigStorageCageFeedTaskService.update( + new LambdaUpdateWrapper<BigStorageCageFeedTask>() + .in(BigStorageCageFeedTask::getGlassId, matchingIds2) + .lt(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_SLOT) + .set(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_UP) + ); + } + } + if (CollectionUtils.isEmpty(glassIds1)) { + S7object.getinstance().plccontrol.writeWord(mesD03Address, 0); + log.info("{}绾夸慨鏀圭幓鐠儃}鐘舵�佷负3", Const.A09_OUT_TARGET_POSITION, glassIds1); + bigStorageCageFeedTaskService.update( + new LambdaUpdateWrapper<BigStorageCageFeedTask>() + .eq(BigStorageCageFeedTask::getLine, Const.A09_OUT_TARGET_POSITION) + .eq(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_UP) + .gt(BigStorageCageFeedTask::getTargetSlot, 0) + .lt(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_SLOT) + .set(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_CAR) + ); + } + if (CollectionUtils.isEmpty(glassIds2)) { + S7object.getinstance().plccontrol.writeWord(mesD05Address, 0); + log.info("{}绾夸慨鏀圭幓鐠儃}鐘舵�佷负3", Const.A10_OUT_TARGET_POSITION, glassIds2); + bigStorageCageFeedTaskService.update( + new LambdaUpdateWrapper<BigStorageCageFeedTask>() + .eq(BigStorageCageFeedTask::getLine, Const.A10_OUT_TARGET_POSITION) + .eq(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_UP) + .gt(BigStorageCageFeedTask::getTargetSlot, 0) + .lt(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_SLOT) + .set(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_CAR) + ); + } + String carRequest = plcParameterObject.getPlcParameter("CarRequest").getValue(); + log.info("澶ц溅褰撳墠鐜荤拑id{}", glassIdsCar); + log.info("鍗ц浆绔�1鐜荤拑id{}", glassIds1); + log.info("鍗ц浆绔�2鐜荤拑id{}", glassIds2); + if (CollectionUtils.isNotEmpty(glassIdsCar) && REQUEST_WORD.equals(carRequest)) { + List<BigStorageCageFeedTask> bigStorageCageFeedTasks = bigStorageCageFeedTaskService.list( + new LambdaQueryWrapper<BigStorageCageFeedTask>() + .in(BigStorageCageFeedTask::getGlassId, glassIdsCar) + .eq(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_UP) + .eq(BigStorageCageFeedTask::getTargetSlot, 0) + ); + if (CollectionUtils.isNotEmpty(bigStorageCageFeedTasks)) { + log.info("璁$畻鐩爣鏍煎瓙鍙戦�佷换鍔}", bigStorageCageFeedTasks); + computeTargetByLineCar(bigStorageCageFeedTasks.get(0).getLine(), glassIdsCar); + } else { + log.info("鍐嶆鍙戦�佽繘鐗囦换鍔}", bigStorageCageFeedTasks); + List<BigStorageCageFeedTask> bigStorageCageFeedTaskList = bigStorageCageFeedTaskService.list( + new LambdaQueryWrapper<BigStorageCageFeedTask>() + .in(BigStorageCageFeedTask::getGlassId, glassIdsCar) + .eq(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_CAR) + .gt(BigStorageCageFeedTask::getTargetSlot, 0) + ); + if (CollectionUtils.isNotEmpty(bigStorageCageFeedTaskList)) { + sendTaskListToPLCCar(bigStorageCageFeedTaskList); + } + } + } + + + } + + /** * 鎸夌収鐜荤拑id鍒ゆ柇鐜荤拑鐘舵�佸強鍗ц浆绔嬫槸鍚﹀彲鐩存帴鍚姩 */ public Boolean judgeGlassTypeStatus(String glassId, Integer line, String mesAddress) { +// 棰勬帓鏍煎瓙 +// computeSlot(glassId); + //鍒ゆ柇姝ょ幓鐠冩槸鍦ㄧ鍐呮垨宸茬敓鎴愯繘鐗囦换鍔� + BigStorageCageFeedTask bigStorageCageFeedTask = bigStorageCageFeedTaskService.getOne( + new LambdaQueryWrapper<BigStorageCageFeedTask>() + .lt(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_SLOT) + .eq(BigStorageCageFeedTask::getGlassId, glassId) + ); + BigStorageCageDetails bigStorageCageDetails = bigStorageCageDetailsService.getOne( + new LambdaQueryWrapper<BigStorageCageDetails>() + .eq(BigStorageCageDetails::getGlassId, glassId) + .eq(BigStorageCageDetails::getState, Const.GLASS_STATE_IN) + ); + if (bigStorageCageFeedTask != null || bigStorageCageDetails != null) { + log.info("姝ょ幓鐠冨瓨浠诲姟鎴栧凡鍦ㄧ鍐�"); + return Boolean.TRUE; + } //1銆佽幏鍙栦换鍔¤〃涓浉閭荤幓鐠� - List<EdgGlassTaskInfo> edgGlassTaskInfoList = edgGlassTaskInfoService.list(new LambdaQueryWrapper<EdgGlassTaskInfo>() + List<EdgGlassTaskInfo> edgGlassTaskInfoList; + edgGlassTaskInfoList = edgGlassTaskInfoService.list(new LambdaQueryWrapper<EdgGlassTaskInfo>() .eq(EdgGlassTaskInfo::getLine, line) - .apply("time >= (select time from edg_glass_task_info where glass_id = '" + glassId + "')") + .apply("time >= (select time from edg_glass_task_info where line='" + line + "' and glass_id = '" + glassId + "' and deleted = 0)") .orderByAsc(EdgGlassTaskInfo::getTime)); + if (edgGlassTaskInfoList.size() == 0) { + edgGlassTaskInfoList = edgGlassTaskInfoService.list(new QueryWrapper<EdgGlassTaskInfo>() + .select("Top 1 *") + .eq("glass_id", glassId) + ); + log.info("鍦ㄥ昂瀵歌〃涓幏鍙栫幓鐠冧俊鎭瘂}", edgGlassTaskInfoList); + if (edgGlassTaskInfoList.size() == 0) { + GlassInfo glassInfo = glassInfoService.getOne( + new LambdaQueryWrapper<GlassInfo>() + .eq(GlassInfo::getGlassId, glassId) + ); + EdgGlassTaskInfo edgGlassTaskInfo = new EdgGlassTaskInfo(); + BeanUtils.copyProperties(glassInfo, edgGlassTaskInfo); + edgGlassTaskInfo.setWidth((int) glassInfo.getWidth() * 10); + edgGlassTaskInfo.setHeight((int) glassInfo.getHeight() * 10); + edgGlassTaskInfoList.add(edgGlassTaskInfo); + log.info("鍦ㄧ幓鐠冧俊鎭〃涓幏鍙栫幓鐠冧俊鎭瘂}", edgGlassTaskInfoList); + } + } Assert.isFalse(CollectionUtils.isEmpty(edgGlassTaskInfoList), "璇嗗埆鐜荤拑淇℃伅鏈嚭鐜板湪灏哄琛ㄤ腑,鑾峰彇鐩搁偦涓ゅ潡鐜荤拑澶辫触"); //2銆佽幏鍙栧崸杞珛鍓╀綑瀹藉害 BigStorageDTO sitToUpRemainWidth = bigStorageCageFeedTaskService.querySitToUpRemainWidth(line); @@ -496,7 +902,11 @@ if (glassCount < inCarMaxSize) { addFeedTask(glassId, line, Const.BIG_STORAGE_IN_WAIT, widthFirst, heightFirst); } else { - addFeedTask(glassId, line, Const.BIG_STORAGE_IN_RUN, widthFirst, heightFirst); + if (glassCount < inCarMaxSize + 1) { + addFeedTask(glassId, line, Const.BIG_STORAGE_IN_RUN, widthFirst, heightFirst); + } else { + return Boolean.FALSE; + } } } else { flag = Boolean.FALSE; @@ -507,12 +917,20 @@ if (remainWidth >= widthFirst) { if (remainWidth - widthFirst - glassGap >= widthSecond) { if (glassCount < inCarMaxSize) { - addFeedTask(glassId, line, Const.BIG_STORAGE_IN_WAIT, widthFirst, heightSecond); + addFeedTask(glassId, line, Const.BIG_STORAGE_IN_WAIT, widthFirst, heightFirst); } else { - addFeedTask(glassId, line, Const.BIG_STORAGE_IN_RUN, widthFirst, heightSecond); + if (glassCount < inCarMaxSize + 1) { + addFeedTask(glassId, line, Const.BIG_STORAGE_IN_RUN, widthFirst, heightFirst); + } else { + return Boolean.FALSE; + } } } else { - addFeedTask(glassId, line, Const.BIG_STORAGE_IN_RUN, widthFirst, heightSecond); + if (glassCount < inCarMaxSize + 1) { + addFeedTask(glassId, line, Const.BIG_STORAGE_IN_RUN, widthFirst, heightFirst); + } else { + return Boolean.FALSE; + } } } else { flag = Boolean.FALSE; @@ -521,17 +939,54 @@ //鍚憄lc鍙戦�佽繘鐗囩‘璁� if (flag) { //鍚憄lc鍐欏叆纭瀛� - int returnData = 0; + PlcParameterObject plcParameterObject = S7object.getinstance().PlcMesObject; + int returnData = 1; int count = 1; - while (returnData == 0) { + while (returnData != 0) { S7object.getinstance().plccontrol.writeWord(mesAddress, 1); - returnData = S7object.getinstance().plccontrol.readWord(mesAddress, 1).get(0); - log.info("杩涘崸杞珛绗瑊}娆″彂閫佺‘璁ゅ瓧瀹屾垚锛屽湴鍧�涓猴細{},鍐欏叆鐨勫唴瀹逛负{}", count++, mesAddress, returnData); + if (Const.A10_OUT_TARGET_POSITION.equals(line)) { + returnData = Integer.parseInt(plcParameterObject.getPlcParameter("D04ToMES").getValue()); + } else { + returnData = Integer.parseInt(plcParameterObject.getPlcParameter("D01ToMES").getValue()); + } +// returnData = S7object.getinstance().plccontrol.readWord(mesAddress, 1).get(0); + log.info("杩涘崸杞珛绗瑊}娆″彂閫佺‘璁ゅ瓧瀹屾垚锛屽湴鍧�涓猴細{},鍐欏叆鐨勫唴瀹逛负{}", count++, mesAddress, 1); } } //璁板綍鏃犳硶鏀句笅鐜荤拑锛屽悗缁垽鏂惎鍔� return flag; + } + + public void computeSlot(String glassId) { + GlassInfo glassInfo = glassInfoService.getOne( + new LambdaQueryWrapper<GlassInfo>() + .eq(GlassInfo::getGlassId, glassId) + ); + if (glassInfo.getTargetSlot() == null) { + List<GlassInfo> glassInfos = glassInfoService.list( + new LambdaQueryWrapper<GlassInfo>() + .eq(GlassInfo::getEngineerId, glassInfo.getEngineerId()) + .eq(GlassInfo::getTemperingLayoutId, glassInfo.getTemperingLayoutId()) + .orderBy(Boolean.TRUE, sequenceOrder, GlassInfo::getTemperingFeedSequence) + ); + List<BigStorageCageDetails> glassInfoLists = new ArrayList<>(); + glassInfos.forEach(item -> { + BigStorageCageDetails details = new BigStorageCageDetails(); + BeanUtils.copyProperties(item, details); + details.setSlot(1); + glassInfoLists.add(details); + }); + computeOutMoreGlassInfo(glassInfoLists, Boolean.TRUE, 2); + for (BigStorageCageOutTask bigStorageCageOutTask : allTask + ) { + glassInfoService.update( + new LambdaUpdateWrapper<GlassInfo>() + .eq(GlassInfo::getGlassId, bigStorageCageOutTask.getGlassId()) + .set(GlassInfo::getTargetSlot, bigStorageCageOutTask.getTrainNumber()) + ); + } + } } /** @@ -546,6 +1001,16 @@ bigStorageCageFeedTask.setWidth(width); bigStorageCageFeedTask.setHeight(height); bigStorageCageFeedTask.setCreateTime(new Date()); + bigStorageCageFeedTask.setTargetSlot(0); + //鍒犻櫎鐞嗙墖绗艰〃鎷胯蛋/鐮存崯鏁版嵁鏁版嵁 + damageService.deleteByGlassId(glassId); + Damage damage = new Damage(); + damage.setGlassId(glassId); + damage.setWorkingProcedure("纾ㄨ竟"); + damage.setLine(line); + damage.setType(1); + damage.setRemark("杩涘ぇ鐞嗙墖"); + damageService.insertDamage(damage); return bigStorageCageFeedTaskService.save(bigStorageCageFeedTask); } @@ -573,10 +1038,20 @@ * 璁$畻浠诲姟琛ㄨ繘鐗囩嚎璺殑鐩爣鏍煎瓙锛屽苟鍚姩浠诲姟 */ public boolean computeTargetByLine(Integer line) { + sendTaskListToPLC(new ArrayList<>(), line); + return true; + } + + /** + * 璁$畻浠诲姟琛ㄨ繘鐗囩嚎璺殑鐩爣鏍煎瓙锛屽苟鍚姩浠诲姟 + */ + public boolean computeTargetByLineCar(Integer line, List<String> carGlassId) { //1銆佽幏鍙栦换鍔¤〃涓殑鎵�鏈夌幓鐠冿紙鎸囧畾绾胯矾涓斿凡缁忚繘鍗ц浆绔嬪畬鎴愶級 List<BigStorageCageFeedTask> taskList = bigStorageCageFeedTaskService.list(new LambdaQueryWrapper<BigStorageCageFeedTask>() .eq(BigStorageCageFeedTask::getLine, line) - .and(e -> e.isNull(BigStorageCageFeedTask::getTargetSlot).or().eq(BigStorageCageFeedTask::getTargetSlot, Const.OUT_TARGET_POSITION_ZERO)) + .in(BigStorageCageFeedTask::getGlassId, carGlassId) + .and(e -> e.isNull(BigStorageCageFeedTask::getTargetSlot).or() + .eq(BigStorageCageFeedTask::getTargetSlot, Const.OUT_TARGET_POSITION_ZERO)) .in(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_UP_ALL) .orderByAsc(BigStorageCageFeedTask::getId)); //2銆佸幓绗煎瓙鍐呮煡鎵炬槸鍚﹀彲浠ョ户缁瓨鏀剧殑绗煎瓙 @@ -597,17 +1072,30 @@ Map<String, GlassInfo> glassInfoMap = glassInfos.stream() .collect(Collectors.toMap(GlassInfo::getGlassId, p -> p)); for (BigStorageCageFeedTask e : taskList) { - GlassInfo info = glassInfoMap.get(e.getGlassId()); + //鏇挎崲鐜荤拑id + queryAndChangeGlass(e.getGlassId()); + GlassInfo info = glassInfoService.getOne( + new LambdaQueryWrapper<GlassInfo>() + .eq(GlassInfo::getGlassId, e.getGlassId()) + ); +// GlassInfo info = glassInfoMap.get(e.getGlassId()); if (info == null) { continue; + } + if (info.getTargetSlot() == null) { + computeSlot(info.getGlassId()); + info = glassInfoService.getOne( + new LambdaQueryWrapper<GlassInfo>() + .eq(GlassInfo::getGlassId, info.getGlassId()) + ); } BigStorageCageDetails cageDetails = new BigStorageCageDetails(); BeanUtils.copyProperties(info, cageDetails); //2銆佽幏鍙栫洰鏍囨牸瀛愪俊鎭� BigStorageDTO bigStorageDTO = bigStorageCageDetailsService.queryTargetSlotByTempering(info); - //3銆佹洿鏂板ぇ鐞嗙墖绗艰〃鍓╀綑瀹藉害锛堟洿鏂板ぇ鐞嗙墖绗煎墿浣欏昂瀵哥Щ鍒拌繘绗煎畬鎴愬悗鎵ц锛� -// bigStorageCageService.update(new LambdaUpdateWrapper<BigStorageCage>().set(BigStorageCage::getRemainWidth, bigStorageDTO.getWidth() - info.getWidth() - glassGap) -// .eq(BigStorageCage::getSlot, bigStorageDTO.getSlot())); + //3銆佷复鏃舵洿鏂版牸瀛愮殑鍓╀綑灏哄锛氶槻姝㈢浉閭荤幓鐠冭繘鍚屼竴鏍煎瓙閫犳垚鍓╀綑灏哄涓嶈冻锛岀幓鐠冭秺鐣岀殑鎯呭喌锛屼换鍔″畬鎴愬悗鍐嶆鏇存柊澶х悊鐗囩琛ㄥ墿浣欏搴︼紙鎸夌収绗煎唴鐜荤拑鏁伴噺鏇存柊澶х悊鐗囩鍓╀綑灏哄锛� + bigStorageCageService.update(new LambdaUpdateWrapper<BigStorageCage>().set(BigStorageCage::getRemainWidth, bigStorageDTO.getWidth() - Math.max(info.getWidth(), info.getHeight()) - glassGap) + .eq(BigStorageCage::getSlot, bigStorageDTO.getSlot())); //4銆佹洿鏂拌繘鐗囦换鍔¤〃锛岀洰鏍囨牸瀛愬強鐘舵�侊紙鐘舵�佹敼涓�2 鐢垫皵鎵埌鑷澶勭悊锛� 閬囧埌闂锛氭棤娉曟壒閲忔洿鏂帮紝鎵归噺鏇存柊鏃犳硶璧版寚瀹氫粠搴� e.setTargetSlot(bigStorageDTO.getSlot()); bigStorageCageFeedTaskService.updateById(e); @@ -618,9 +1106,28 @@ cageDetails.setDeviceId(bigStorageDTO.getDeviceId()); cageDetails.setGap(glassGap); bigStorageCageDetailsService.save(cageDetails); + } - sendTaskListToPLC(taskList, line); + sendTaskListToPLCCar(taskList); return Boolean.TRUE; + } + + private void sendTaskListToPLCCar(List<BigStorageCageFeedTask> taskList) { + S7control s7control = S7object.getinstance().plccontrol; + PlcParameterObject plcMesObject = S7object.getinstance().PlcMesObject; + List<String> returnData = new ArrayList<>(); + for (int i = 1; i <= taskList.size(); i++) { + s7control.writeWord(plcMesObject.getPlcParameter("StartAddToImport" + i).getAddress(), taskList.get(i - 1).getLine()); + s7control.writeWord(plcMesObject.getPlcParameter("TargetAddToImport" + i).getAddress(), taskList.get(i - 1).getTargetSlot()); + returnData.add(taskList.get(i - 1).getGlassId()); + log.info("鍚憄lc鍙戦�佺{}鐗囩幓鐠冨凡瀹屾垚,璧峰浣嶇疆鏄瘂}锛岀洰鏍囦綅缃槸", i, taskList.get(i - 1).getLine(), taskList.get(i - 1).getTargetSlot()); + } + String carRequest = plcMesObject.getPlcParameter("CarRequest").getValue(); + String CarResponse = plcMesObject.getPlcParameter("CarResponse").getAddress(); + while (REQUEST_WORD.equals(carRequest)) { + s7control.writeWord(CarResponse, 1); + carRequest = plcMesObject.getPlcParameter("CarRequest").getValue(); + } } private void sendTaskListToPLC(List<BigStorageCageFeedTask> taskList, Integer line) { @@ -630,19 +1137,65 @@ String mesD03Address = plcMesObject.getPlcParameter("MESToD03").getAddress(); String mesD05Address = plcMesObject.getPlcParameter("MESToD05").getAddress(); String outLine = line.equals(Const.A09_OUT_TARGET_POSITION) ? mesD03Address : mesD05Address; - for (int i = 1; i <= taskList.size(); i++) { - s7control.writeWord(plcMesObject.getPlcParameter("StartAddToImport" + i).getAddress(), taskList.get(i - 1).getLine()); - s7control.writeWord(plcMesObject.getPlcParameter("TargetAddToImport" + i).getAddress(), taskList.get(i - 1).getTargetSlot()); - } - int returnData = 0; + List<String> returnData = new ArrayList<>(); + returnData.add("glassid"); +// for (int i = 1; i <= taskList.size(); i++) { +// s7control.writeWord(plcMesObject.getPlcParameter("StartAddToImport" + i).getAddress(), taskList.get(i - 1).getLine()); +// s7control.writeWord(plcMesObject.getPlcParameter("TargetAddToImport" + i).getAddress(), taskList.get(i - 1).getTargetSlot()); +// returnData.add(taskList.get(i - 1).getGlassId()); +// log.info("鍚憄lc鍙戦�佺{}鐗囩幓鐠冨凡瀹屾垚,璧峰浣嶇疆鏄瘂}锛岀洰鏍囦綅缃槸", i, taskList.get(i - 1).getLine(), taskList.get(i - 1).getTargetSlot()); +// } +// int returnData = 1; int count = 1; - while (returnData == 0) { + + + while (CollectionUtils.isNotEmpty(returnData)) { + List<String> glassIds1 = new ArrayList<>(); + List<String> glassIds2 = new ArrayList<>(); s7control.writeWord(outLine, 2); - returnData = s7control.readWord(outLine, 1).get(0); - log.info("宸插悜plc绗瑊}娆″彂閫佸嚭鐗囦换鍔$‘璁わ紝鍦板潃涓猴細{},鍐欏叆鐨勫唴瀹逛负{}", count++, outLine, returnData); + for (int i = 1; i <= 6; i++) { + String line1GlassId = plcMesObject.getPlcParameter("D03ID" + i).getValue(); + if (StringUtils.isNotEmpty(line1GlassId)) { + glassIds1.add(line1GlassId); + } + String line2GlassId = plcMesObject.getPlcParameter("D05ID" + i).getValue(); + if (StringUtils.isNotEmpty(line2GlassId)) { + glassIds2.add(line2GlassId); + } + } + if (line.equals(Const.A09_OUT_TARGET_POSITION)) { +// returnData = Integer.parseInt(plcMesObject.getPlcParameter("D03ToMES").getValue()); + returnData = glassIds1; + } else { +// returnData = Integer.parseInt(plcMesObject.getPlcParameter("D05ToMES").getValue()); + returnData = glassIds2; + } +// returnData = s7control.readWord(outLine, 1).get(0); + log.info("宸插悜plc绗瑊}娆″彂閫佽繘鐗囧崸杞珛锛屽湴鍧�涓猴細{},鍐欏叆鐨勫唴瀹逛负{},璇诲埌鐨勮姹備负{}", count++, outLine, 2, returnData); } +// while (returnData != 0) { +// s7control.writeWord(outLine, 2); +// if (line.equals(Const.A09_OUT_TARGET_POSITION)) { +//// returnData = Integer.parseInt(plcMesObject.getPlcParameter("D03ToMES").getValue()); +// returnData = s7control.readWord(plcMesObject.getPlcParameter("D03Request").getAddress(), 1).get(0); +// } else { +//// returnData = Integer.parseInt(plcMesObject.getPlcParameter("D05ToMES").getValue()); +// returnData = s7control.readWord(plcMesObject.getPlcParameter("D05Request").getAddress(), 1).get(0); +// } +//// returnData = s7control.readWord(outLine, 1).get(0); +// log.info("宸插悜plc绗瑊}娆″彂閫佽繘鐗囦换鍔$‘璁わ紝鍦板潃涓猴細{},鍐欏叆鐨勫唴瀹逛负{},璇诲埌鐨勮姹備负{}", count++, outLine, 2,returnData); +// } } + /** + * 鍑虹墖涓�娆′粎鐢熸垚涓�杞︾幓鐠� + * + * @param list + * @param isTempering + * @param mesToPLCAddress + * @param <T> + * @return + */ private <T extends BigStorageCageBaseInfo> Boolean computeOutGlassInfo(List<T> list, Boolean isTempering, String mesToPLCAddress) { //浠诲姟鏁版嵁 鑾峰彇杞﹀瓙瀛樻斁鐜荤拑鏈�澶ф暟閲� 鐜荤拑闂撮殧 List<BigStorageCageOutTask> bigStorageCageOutTaskList = new ArrayList<>(); @@ -650,15 +1203,15 @@ Integer remainWidth = carWidth; int maxX = 0; for (T e : list) { - if (bigStorageCageOutTaskList.size() >= outCarMaxSize || e.getWidth() > remainWidth) { + if (bigStorageCageOutTaskList.size() >= outCarMaxSize || Math.max((int) e.getWidth(), (int) e.getHeight()) > remainWidth) { break; } - remainWidth = remainWidth - (int) e.getWidth() - glassGap; + remainWidth = remainWidth - Math.max((int) e.getWidth(), (int) e.getHeight()) - glassGap; if (isTempering) { int minLength = Math.min((int) e.getWidth(), (int) e.getHeight()); if (maxX + minLength <= xMaxSize) { bigStorageCageOutTaskList.add(new BigStorageCageOutTask(e.getGlassId(), e.getSlot(), Const.TEMPERING_OUT_TARGET_POSITION, - e.getWidth() * 10, e.getHeight() * 10, 0, 0, 1)); + e.getWidth() * 10, e.getHeight() * 10, 0, 0, 1, new Date())); maxX = Math.max(maxX, e.getXCoordinate()); } else { break; @@ -666,9 +1219,8 @@ } else { bigStorageCageOutTaskList.add(new BigStorageCageOutTask(e.getGlassId(), e.getSlot(), Const.ARTIFICIAL_OUT_TARGET_POSITION, - e.getWidth() * 10, e.getHeight(), 0, 0, 1)); + e.getWidth() * 10, e.getHeight(), 0, 0, 1, new Date())); } - } Assert.isFalse(CollectionUtils.isEmpty(bigStorageCageOutTaskList), "鏈幏鍙栧嚭鐗囨暟鎹紝缁撴潫鍑虹墖浠诲姟"); log.info("鑾峰彇鍑虹墖浠诲姟鏁版嵁{}鏉★紝鎵ц淇濆瓨", bigStorageCageOutTaskList.size()); @@ -678,9 +1230,6 @@ bigStorageCageDetailsService.update(new LambdaUpdateWrapper<BigStorageCageDetails>() .set(BigStorageCageDetails::getState, Const.GLASS_STATE_OUT_ING) .in(BigStorageCageDetails::getGlassId, glassIds)); - //鏇存柊绗煎瓙鍐呮牸瀛愮殑鍓╀綑灏哄(绉昏嚦鍑虹墖浠诲姟瀹屾垚鍚�) -// updateSlotRemain(list, glassIds); - int returnData = 0; int count = 1; while (returnData == 0) { @@ -692,46 +1241,127 @@ } /** - * 鏇存柊绗煎瓙鍐呮牸瀛愮殑鍓╀綑灏哄 + * 鍑虹墖涓�娆$敓鎴愪竴鐐夌幓鐠� * - * @param taskGlassIds 鏈浠诲姟鍑哄幓鐨勭幓鐠僫ds - * @param flag 鏄惁杩涘嚭鐗� true 杩涚墖 false 鍑虹墖 + * @param list + * @param isTempering + * @param isTask + * @param <T> + * @return */ - public void updateSlotRemain(List<String> taskGlassIds, Boolean flag) { - //鎸夌収鐜荤拑id鑾峰彇鐜荤拑淇℃伅鍙婄幓鐠冪殑鏍煎瓙鍙� - List<BigStorageCageDetails> glassList = bigStorageCageDetailsService.list(new LambdaQueryWrapper<BigStorageCageDetails>() - .in(BigStorageCageDetails::getGlassId, taskGlassIds)); - //鑾峰彇闇�瑕佸嚭鍘�/杩涚锛堝寘鎷緟鍑哄幓鐨勶級鐨勬墍鏈夌幓鐠冩牸瀛愬彿 - List<Integer> slotList = glassList.stream().map(BigStorageCageDetails::getSlot).distinct().collect(Collectors.toList()); + public <T extends BigStorageCageBaseInfo> Boolean computeOutMoreGlassInfo(List<T> list, Boolean isTempering, Integer isTask) { + //浠诲姟鏁版嵁 鑾峰彇杞﹀瓙瀛樻斁鐜荤拑鏈�澶ф暟閲� 鐜荤拑闂撮殧 + List<BigStorageCageOutTask> bigStorageCageOutTaskList = new ArrayList<>(); + //鎵撹溅鍓╀綑灏哄 + Integer remainWidth = carWidth; + int trainNumber = 1; + int serialNumber = 1; + int maxX = 0; + int slot = 0; + for (T e : list) { + int maxLength = Math.max((int) e.getWidth(), (int) e.getHeight()); + if (isTempering) { + int minLength = Math.min((int) e.getWidth(), (int) e.getHeight()); + if (maxX + minLength <= xMaxSize && serialNumber <= outCarMaxSize && remainWidth > maxLength) { + if (slot != e.getSlot() && slot != 0) { + int finalMaxX = maxX; + int finalSerialNumber = serialNumber; + int finalRemainWidth = remainWidth; + List<T> lists = list.stream().filter(t -> t.getSlot() == (int) e.getSlot()).collect(Collectors.toList()); + for (T x : lists) { + int finalMinLength = Math.min((int) x.getWidth(), (int) x.getHeight()); + int finalMaxLength = Math.max((int) e.getWidth(), (int) e.getHeight()); + if (finalMaxX + finalMinLength > xMaxSize || finalSerialNumber > outCarMaxSize || finalMaxLength > finalRemainWidth) { + remainWidth = carWidth; + trainNumber = trainNumber + 1; + serialNumber = 1; + maxX = 0; + break; + } else { + finalMaxX = Math.max(maxX, x.getXCoordinate()); + finalRemainWidth = finalRemainWidth - finalMaxLength - glassGap; + finalSerialNumber++; + } + } + } + bigStorageCageOutTaskList.add(new BigStorageCageOutTask(e.getGlassId(), e.getSlot(), Const.TEMPERING_OUT_TARGET_POSITION, + e.getWidth() * 10, e.getHeight() * 10, trainNumber, serialNumber++, 1, new Date())); + remainWidth = remainWidth - maxLength - glassGap; + maxX = Math.max(maxX, e.getXCoordinate()); + slot = e.getSlot(); + } else { + remainWidth = carWidth - maxLength - glassGap; + trainNumber = trainNumber + 1; + serialNumber = 1; + maxX = e.getXCoordinate(); + slot = e.getSlot(); + bigStorageCageOutTaskList.add(new BigStorageCageOutTask(e.getGlassId(), e.getSlot(), Const.TEMPERING_OUT_TARGET_POSITION, + e.getWidth() * 10, e.getHeight() * 10, trainNumber, serialNumber++, 1, new Date())); + } + } else { + if(serialNumber <= outCarMaxSize && remainWidth > maxLength){ + remainWidth = remainWidth - maxLength - glassGap; + bigStorageCageOutTaskList.add(new BigStorageCageOutTask(e.getGlassId(), e.getSlot(), Const.ARTIFICIAL_OUT_TARGET_POSITION, + e.getWidth() * 10, e.getHeight() * 10, trainNumber, serialNumber++, 1, new Date())); + }else{ + remainWidth = carWidth - maxLength - glassGap; + trainNumber = trainNumber + 1; + serialNumber = 1; + bigStorageCageOutTaskList.add(new BigStorageCageOutTask(e.getGlassId(), e.getSlot(), Const.ARTIFICIAL_OUT_TARGET_POSITION, + e.getWidth() * 10, e.getHeight() * 10, trainNumber, serialNumber++, 1, new Date())); + } + + } + } + if (isTask == 2) { + allTask = bigStorageCageOutTaskList; + return Boolean.FALSE; + } else if (isTask == 3) { + notAllTask = bigStorageCageOutTaskList; + return Boolean.FALSE; + } + Assert.isFalse(CollectionUtils.isEmpty(bigStorageCageOutTaskList), "鏈幏鍙栧嚭鐗囨暟鎹紝缁撴潫鍑虹墖浠诲姟"); + log.info("鑾峰彇鍑虹墖浠诲姟鏁版嵁{}鏉★紝鎵ц淇濆瓨", bigStorageCageOutTaskList.size()); + bigStorageCageOutTaskService.saveBatch(bigStorageCageOutTaskList); + List<String> glassIds = bigStorageCageOutTaskList.stream().map(BigStorageCageOutTask::getGlassId).collect(Collectors.toList()); + log.info("灏嗗嚭鐗囩幓鐠儃}鐜荤拑鐘舵�佹敼涓哄凡鍑虹墖", glassIds); + bigStorageCageDetailsService.update(new LambdaUpdateWrapper<BigStorageCageDetails>() + .set(BigStorageCageDetails::getState, Const.GLASS_STATE_OUT_ING) + .in(BigStorageCageDetails::getGlassId, glassIds) + .ne(BigStorageCageDetails::getState, Const.GLASS_STATE_OUT)); +// int returnData = 0; +// int count = 1; +// while (returnData == 0) { +// S7object.getinstance().plccontrol.writeWord(mesToPLCAddress, 1); +// returnData = S7object.getinstance().plccontrol.readWord(mesToPLCAddress, 1).get(0); +// log.info("宸插悜plc绗瑊}娆″彂閫佸嚭鐗囦换鍔$‘璁わ紝鍦板潃涓猴細{},鍐欏叆鐨勫唴瀹逛负{}", count++, mesToPLCAddress, returnData); +// } + return Boolean.TRUE; + } + + public void updateSlotRemainBySlots(List<Integer> slotList) { //鑾峰彇鏍煎瓙鍐呮墍鏈夌殑鐜荤拑淇℃伅 List<BigStorageCageDetails> inSlotGlassList = bigStorageCageDetailsService.list(new LambdaQueryWrapper<BigStorageCageDetails>() .in(BigStorageCageDetails::getSlot, slotList).in(BigStorageCageDetails::getState, Const.GLASS_STATE_IN_ALL)); - //鑾峰彇寰呰繘鐗�/鍑哄幓鐨勭幓鐠冧俊鎭� - Map<Integer, Double> slotRemainMap = null; - if (flag) { - slotRemainMap = inSlotGlassList.stream().filter(e -> taskGlassIds.contains(e.getGlassId())) - .collect(Collectors.groupingBy(BigStorageCageDetails::getSlot, Collectors.summingDouble(item -> item.getWidth() + glassGap))); - } else { - slotRemainMap = inSlotGlassList.stream().filter(e -> !taskGlassIds.contains(e.getGlassId())) - .collect(Collectors.groupingBy(BigStorageCageDetails::getSlot, Collectors.summingDouble(item -> item.getWidth() + glassGap))); - } - //鏍煎瓙鍐呮湁鐜荤拑鐨勶紝璁$畻涓猴細 鏍煎瓙鐨勫搴� - 锛堢粰瀛愬唴鐜荤拑鐨勫昂瀵�+闂磋窛锛� - if (CollectionUtils.isNotEmpty(slotRemainMap)) { + Map<Integer, Double> slotRemainMap = new HashMap<>(); + //鏄惁瀛樺湪鏈夋牸瀛愰潪绌虹殑鐜荤拑 + if (CollectionUtils.isNotEmpty(inSlotGlassList)) { + //瀛樺湪 灏嗘牸瀛愬唴鐨勭幓鐠冨垎鍒繘琛屾洿鏂� + slotRemainMap = inSlotGlassList.stream() + .collect(Collectors.groupingBy(BigStorageCageDetails::getSlot, Collectors.summingDouble(item -> Math.max(item.getWidth(), item.getHeight()) + glassGap))); slotRemainMap.forEach((e, v) -> { - bigStorageCageService.update(new LambdaUpdateWrapper<BigStorageCage>().set(BigStorageCage::getRemainWidth, slotWidth - v) + double remainWidth = slotWidth - v >= 0 ? slotWidth - v : 0; + bigStorageCageService.update(new LambdaUpdateWrapper<BigStorageCage>().set(BigStorageCage::getRemainWidth, remainWidth) .eq(BigStorageCage::getSlot, e)); }); } - //鍙洿鏂拌繘绗煎畬鎴愮殑鐘舵�侊紝濡傛灉杩涚瀹屾垚锛屾牸瀛愬唴蹇呭畾鏈夌幓鐠冿紝涓嶅瓨鍦ㄥ嚭鐗囧悗鏍煎瓙鍐呮病鏈夌幓鐠冪殑鎯呭喌锛屾墍鏈夋牸瀛愬昂瀵搁噸缃紝鍙兘瀛樺湪浜庡嚭鐗囦换鍔� - if (!flag) { - Set<Integer> remainSlotList = slotRemainMap.keySet(); - slotList.removeAll(remainSlotList); - if (CollectionUtils.isNotEmpty(slotList)) { - bigStorageCageService.update(new LambdaUpdateWrapper<BigStorageCage>().set(BigStorageCage::getRemainWidth, slotWidth) - .in(BigStorageCage::getSlot, slotList)); - } + //杩囨护涓嶅瓨鍦ㄧ幓鐠冪殑鏍煎瓙 灏嗗搴﹂噸缃负鍘熷瀹藉害5000 + List<Integer> remainSlotList = new ArrayList<>(slotRemainMap.keySet()); + slotList.removeAll(remainSlotList); + if (CollectionUtils.isNotEmpty(slotList)) { + bigStorageCageService.update(new LambdaUpdateWrapper<BigStorageCage>().set(BigStorageCage::getRemainWidth, slotWidth) + .in(BigStorageCage::getSlot, slotList)); } - } public Boolean computeIsRun(int line, String glassId) { @@ -740,9 +1370,52 @@ if (sitToUpRemainWidth.getGlassCount() == 0) { return Boolean.FALSE; } + List<Integer> lineList = bigStorageCageFeedTaskService.querySitToUpGlass(); + if (CollectionUtils.isNotEmpty(lineList)) { + Integer lineFirst = lineList.get(0); + if (line == lineFirst) { + return Boolean.TRUE; + } else { + return Boolean.FALSE; + } + } else { + return Boolean.FALSE; + } + //鑾峰彇鐜荤拑淇℃伅 +// GlassInfo glassInfo = glassInfoService.getOne(new LambdaQueryWrapper<GlassInfo>().eq(GlassInfo::getGlassId, glassId)); +// return sitToUpRemainWidth.getWidth() < Math.max(glassInfo.getWidth(), glassInfo.getHeight()); + } + + public String queryAndChangeGlass(String glassId) { GlassInfo glassInfo = glassInfoService.getOne(new LambdaQueryWrapper<GlassInfo>().eq(GlassInfo::getGlassId, glassId)); - return sitToUpRemainWidth.getWidth() < Math.max(glassInfo.getWidth(), glassInfo.getHeight()); + Assert.isFalse(null == glassInfo, "鐜荤拑淇℃伅涓嶅瓨鍦�"); //鎸夌収鐜荤拑灏哄 + LambdaQueryWrapper<GlassInfo> queryWrapper = new LambdaQueryWrapper<GlassInfo>() + .eq(GlassInfo::getWidth, glassInfo.getWidth()) + .eq(GlassInfo::getHeight, glassInfo.getHeight()) + .eq(GlassInfo::getThickness, glassInfo.getThickness()) + .eq(GlassInfo::getFilmsid, glassInfo.getFilmsid()) + .eq(GlassInfo::getFlowCardId, glassInfo.getFlowCardId()) + .eq(GlassInfo::getTotalLayer, glassInfo.getTotalLayer()) + .eq(GlassInfo::getLayer, glassInfo.getLayer()) + .eq(GlassInfo::getEngineerId, glassInfo.getEngineerId()) + .eq(GlassInfo::getMarkIcon, glassInfo.getMarkIcon()) + .notInSql(GlassInfo::getGlassId, "select distinct glass_id from big_storage_cage_details " + + "where engineer_id = '" + glassInfo.getEngineerId() + "' and width = " + glassInfo.getWidth() + " and height = " + glassInfo.getHeight()) + .orderByAsc(GlassInfo::getTemperingLayoutId) + .orderBy(Boolean.TRUE, sequenceOrder, GlassInfo::getTemperingFeedSequence) + .last("Limit 1"); + GlassInfo swapGlassInfo = glassInfoService.getOne(queryWrapper); + if (swapGlassInfo != null && !glassInfo.getGlassId().equals(swapGlassInfo.getGlassId())) { + String swapGlassId = swapGlassInfo.getGlassId(); + log.info("灏嗙幓鐠儃}鍜岀幓鐠儃}锛屼俊鎭簰鎹�,杩涚幓鐠� {}", glassInfo, swapGlassInfo, swapGlassInfo); + swapGlassInfo.setGlassId(glassId); + glassInfo.setGlassId(swapGlassId); + glassInfoService.updateById(swapGlassInfo); + glassInfoService.updateById(glassInfo); + return swapGlassId; + } + return ""; } } \ No newline at end of file -- Gitblit v1.8.0