From acdc4b3427cbd2a6dc811aed202fbd3e9c309d69 Mon Sep 17 00:00:00 2001
From: 18516761980 <4761516tqsxp>
Date: 星期五, 05 十一月 2021 10:57:12 +0800
Subject: [PATCH] #
---
src/main/java/com/zy/asrs/service/impl/BasAgvServiceImpl.java | 81 ++++++++++++++++++++++++++++++++++++++++
1 files changed, 81 insertions(+), 0 deletions(-)
diff --git a/src/main/java/com/zy/asrs/service/impl/BasAgvServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/BasAgvServiceImpl.java
index c1ab0d6..7afc456 100644
--- a/src/main/java/com/zy/asrs/service/impl/BasAgvServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/BasAgvServiceImpl.java
@@ -1,12 +1,93 @@
package com.zy.asrs.service.impl;
+import com.baomidou.mybatisplus.mapper.EntityWrapper;
+import com.core.common.Cools;
+import com.core.exception.CoolException;
import com.zy.asrs.mapper.BasAgvMapper;
import com.zy.asrs.entity.BasAgv;
import com.zy.asrs.service.BasAgvService;
import com.baomidou.mybatisplus.service.impl.ServiceImpl;
+import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
+import java.util.List;
+import java.util.Random;
+
+@Slf4j
@Service("basAgvService")
public class BasAgvServiceImpl extends ServiceImpl<BasAgvMapper, BasAgv> implements BasAgvService {
+ @Override
+ public BasAgv selectIdleAgv() {
+ List<BasAgv> idleAgvs = this.selectList(new EntityWrapper<BasAgv>()
+ .eq("in_enable", "Y")
+ .eq("is_user", 1)
+ .in("status", 6, 8 ,12)
+ );
+ if (Cools.isEmpty(idleAgvs)) {
+ log.warn("娌℃湁绌洪棽鐨凙gv灏忚溅");
+ throw new CoolException("娌℃湁绌洪棽鐨凙gv灏忚溅");
+ }
+ return idleAgvs.get(0);
+ }
+
+ @Override
+ public Boolean haveIdleAgv() {
+ List<BasAgv> idleAgvs = this.selectList(new EntityWrapper<BasAgv>()
+ .eq("in_enable", "Y")
+ .eq("is_user", 1)
+ .in("status", 6, 8 ,12)
+ );
+ if (Cools.isEmpty(idleAgvs)) {
+ log.warn("娌℃湁绌洪棽鐨凙gv灏忚溅");
+ return false;
+ }
+ return true;
+ }
+
+ @Override
+ public String getAgvWorkNo() {
+ String workNo = null;
+ for (int i = 0; i < 10; i++) {
+ workNo = getRandom();
+ int count = this.selectCount(new EntityWrapper<BasAgv>().eq("task_code", workNo));
+ if (count == 0) {
+ break;
+ }
+ }
+ if (Cools.isEmpty(workNo)) {
+ throw new CoolException("涓嬪彂AGV浠诲姟閿欒锛屽伐浣滃彿寮傚父");
+ }
+ return workNo;
+ }
+
+ @Override
+ public String getEmptyAgvWorkNo() {
+ String workNo = null;
+ for (int i = 0; i < 10; i++) {
+ workNo = getEmptyRandom();
+ int count = this.selectCount(new EntityWrapper<BasAgv>().eq("task_code", workNo));
+ if (count == 0) {
+ break;
+ }
+ }
+ if (Cools.isEmpty(workNo)) {
+ throw new CoolException("涓嬪彂AGV浠诲姟閿欒锛屽伐浣滃彿寮傚父");
+ }
+ return workNo;
+ }
+
+
+ private String getRandom() {
+ return String.format("%06d",new Random().nextInt(700000));
+ }
+
+ public String getEmptyRandom(){
+ int min = 700001;
+ int max = 999999;
+ Random random = new Random();
+ int s = random.nextInt(max) % (max - min + 1) + min;
+ return String.format("%06d", s);
+ }
+
}
--
Gitblit v1.9.1