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.github.yulichang.query.MPJQueryWrapper; import com.mes.downglassinfo.entity.DownGlassInfo; import com.mes.downglassinfo.entity.DownGlassTask; import com.mes.downglassinfo.mapper.DownGlassInfoMapper; 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.entity.DownWorkstionAndDownGlassinfo; 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 lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; @Slf4j @Service public class DownWorkstationServiceImpl extends ServiceImpl implements DownWorkstationService { @Autowired private DownWorkstationMapper downWorkstationMapper; @Autowired(required=false) private DownWorkstationTaskMapper downWorkstationTaskMapper; @Autowired private DownGlassInfoService downGlassInfoService; @Autowired private DownGlassInfoMapper downGlassInfoMapper; @Autowired private DownGlassTaskService downGlassTaskService; @Autowired private DownWorkstationTaskService downWorkstationTaskService; // @Override // public List gettwoDownWorkstations() { // return downWorkstationMapper.getDownWorkstationsInRange(6,10); // } //获取总数量 @Override public int getTotalQuantity(int workstationId) { DownWorkstation result = baseMapper.selectOne(new QueryWrapper().lambda() .select(DownWorkstation::getTotalquantity) .eq(DownWorkstation::getWorkstationId, workstationId)); return result != null ? result.getTotalquantity() : 0; } //工位显示 @Override public List> getTotalGlassDimensionsByWorkstation(int start,int end) { MPJQueryWrapper queryWrapper = new MPJQueryWrapper<>(); queryWrapper.select("t.workstation_id", "t.flow_card_id", "COALESCE(SUM(b.width), 0) AS totalwidth", "COALESCE(SUM(b.height), 0) AS totalheight") .leftJoin("down_glass_info b on t.flow_card_id = b.flow_card_id") .groupBy("t.workstation_id", "t.flow_card_id") .orderByAsc("t.workstation_id").between("t.workstation_id", start, end) ; List workstationList = downWorkstationMapper.selectJoinList(DownWorkstionAndDownGlassinfo.class, queryWrapper); // List workstationList = null; List> result = new ArrayList<>(); for (DownWorkstionAndDownGlassinfo downWorkstionAndDownGlassinfo : workstationList) { Map rack = new HashMap<>(); // 创建子项(item)对象 Map item = new HashMap<>(); item.put("height", downWorkstionAndDownGlassinfo.getTotalheight()); // 设置子项高度,根据实际情况设置 item.put("width", downWorkstionAndDownGlassinfo.getTotalwidth()); // 设置子项宽度,根据实际情况设置 item.put("fillColor", "yellow"); // 设置子项颜色 item.put("content", downWorkstionAndDownGlassinfo.getFlowCardId()); // 使用流程卡号作为子项内容 rack.put("item", item); // 将子项对象放入货架对象中 result.add(rack); // 将货架对象添加到结果列表中 //log.info("货架对象: {}", rack); } return result; // 返回最终结果 } //根据条件获取落架数量 @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(new DownWorkstation(), 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(new DownWorkstation(), 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(new DownWorkstation(), updateWrapper); } @Override public DownWorkstation selectByFlowCardId(String flowcardid) { QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.eq("flow_card_id", flowcardid); return baseMapper.selectOne(queryWrapper); } @Transactional public void crossDatabaseQuery() { // 从 MySQL 数据库中查询数据,只返回一条符合条件的数据 DownWorkstation downWorkstation = downWorkstationTaskMapper.selectdownWorkstationstate(); // 从 SQL Server 数据库中查询数据 List downWorkstationTasks = downWorkstationTaskMapper.selectList(); } }