package com.mes.downworkstation.service.impl; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.mes.downglassinfo.entity.DownGlassInfo; import com.mes.downglassinfo.entity.DownGlassTask; import com.mes.downglassinfo.service.DownGlassInfoService; import com.mes.downglassinfo.service.DownGlassTaskService; import com.mes.downworkstation.entity.DownWorkstation; import com.mes.downworkstation.entity.DownWorkstationTask; import com.mes.downworkstation.mapper.DownWorkstationMapper; import com.mes.downworkstation.mapper.DownWorkstationTaskMapper; import com.mes.downworkstation.service.DownWorkstationService; import com.mes.downworkstation.service.DownWorkstationTaskService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import java.util.List; import java.util.Map; @Service public class DownWorkstationServiceImpl extends ServiceImpl implements DownWorkstationService { @Autowired private DownWorkstationMapper downWorkstationMapper; @Autowired private DownWorkstationTaskMapper downWorkstationTaskMapper; @Autowired private DownGlassInfoService downGlassInfoService; @Autowired private DownGlassTaskService downGlassTaskService; @Autowired private DownWorkstationService downWorkstationService; @Autowired private DownWorkstationTaskService downWorkstationTaskService; // @Override // public List gettwoDownWorkstations() { // return downWorkstationMapper.getDownWorkstationsInRange(6,10); // } //获取总数量 @Override public int getTotalQuantity(int workstationId) { QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.select("total_quantity") .eq("workstation_id", workstationId); DownWorkstation result = baseMapper.selectOne(queryWrapper); return result != null ? result.getTotalquantity() : 0; } // @Override // public int getTotalQuantity(int workstationId) { // Integer totalQuantity = downWorkstationMapper.getTotalQuantity(workstationId); // return totalQuantity != null ? totalQuantity : 0; // } // @Override // public int getRacksNumber(int workstationId) { // Integer racksNumber = downWorkstationMapper.getRacksNumber(workstationId); // return racksNumber != null ? racksNumber : 0; // } //根据条件获取落架数量 @Override public int getRacksNumber(int workstationId) { QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.select("racks_number") .eq("workstation_id", workstationId); DownWorkstation result = baseMapper.selectOne(queryWrapper); return result != null ? result.getRacksnumber() : 0; } //根据条件获取工位玻璃信息 @Override public List getoneDownWorkstations(int startId, int endId) { QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.between("workstation_id", startId, endId); return baseMapper.selectList(queryWrapper); } // @Override public void updateracksnumber(String flowCardId, int racksNumber) { UpdateWrapper updateWrapper = new UpdateWrapper<>(); updateWrapper.set("racks_number",racksNumber).eq("flow_card_id", flowCardId); baseMapper.update(null, updateWrapper); } @Override public int updateFlowCardIdAndCount(String flowCardId, int glassInfoCount, int workstationId) { UpdateWrapper updateWrapper = new UpdateWrapper<>(); updateWrapper.set("total_quantity", glassInfoCount) .set("flow_card_id", flowCardId) .eq("workstation_id", workstationId); return baseMapper.update(null, updateWrapper); } @Override public void clearFlowCardId(int workstationId) { UpdateWrapper updateWrapper = new UpdateWrapper<>(); updateWrapper.set("flow_card_id", null) .set("total_quantity", 0) .set("racks_number", 0) .eq("workstation_id", workstationId); baseMapper.update(null, updateWrapper); } @Transactional public void crossDatabaseQuery() { // 从 MySQL 数据库中查询数据,只返回一条符合条件的数据 DownWorkstation downWorkstation = downWorkstationTaskMapper.selectdownWorkstationstate(); // 从 SQL Server 数据库中查询数据 List downWorkstationTasks = downWorkstationTaskMapper.selectList(); } @Override public void insertdownglassinfo() { List taskdownGlassInf = downGlassTaskService.getUnloadingTaskState(); // if (taskdownGlassInf != null && !taskdownGlassInf.isEmpty()) { // for (DownGlassTask downGlassInfo : taskdownGlassInf) { // 创建新的 DownGlassInfo 对象并设置相关属性 DownGlassInfo newdownGlassInfo = new DownGlassInfo(); newdownGlassInfo.setFlowCardId(downGlassInfo.getFlowCardId()); Integer maxSequence = downGlassInfoService.getMaxSequenceByFlowCardId(downGlassInfo.getFlowCardId()); // 初始化顺序字段值 int sequence = maxSequence != null ? maxSequence + 1 : 1; newdownGlassInfo.setWidth(downGlassInfo.getWidth()); newdownGlassInfo.setHeight(downGlassInfo.getHeight()); newdownGlassInfo.setThickness(downGlassInfo.getThickness()); newdownGlassInfo.setFilmsid(downGlassInfo.getFilmsid()); // 设置顺序字段值 newdownGlassInfo.setSequence(sequence); // 插入数据到下片玻璃信息表 downGlassInfoService.insertDownGlassInfo(newdownGlassInfo); //插入数据到机械手任务表 downWorkstationTaskService.insertdownWorkstationtask(newdownGlassInfo); //更新下片任务表状态为0 downGlassTaskService.updateTaskStateToZero(downGlassInfo.getId()); sequence++; // 递增顺序字段值 } } try { //查询下片工位表中架子是否绑定了流程卡号 工位表和任务表中状态为1的流程卡号和已落架数量 List taskdownWorkstation = downWorkstationMapper.selectdownWorkstationstate(); if (taskdownWorkstation != null && !taskdownWorkstation.isEmpty()) { //,如果已经绑定则更新已落架数量,并且删除下片任务表中的记录 for (DownWorkstation downWorkstation : taskdownWorkstation) { //更新下片工位表中已落架数量 downWorkstationService.updateracksnumber(downWorkstation.getFlowCardId(), downWorkstation.getRacksnumber() + 1); //更新机械任务表中状态为0 downWorkstationTaskService.updateTaskStateToZero(downWorkstation.getId()); //删除下片任务表中的记录 downGlassTaskService.deleteTask(downWorkstation.getId()); } } } catch (Exception e) { // 打印异常信息 e.printStackTrace(); // 或者可以进行其他异常处理,比如记录日志或者返回特定的错误信息 } } }