| | |
| | | using WIDESEA_Core.Const; |
| | | using WIDESEA_DTO.MOM; |
| | | using WIDESEA_DTO.WMS; |
| | | using WIDESEA_Model.Models; |
| | | using WIDESEAWCS_Model.Models; |
| | | using WIDESEAWCS_QuartzJob.Models; |
| | | |
| | |
| | | // .FirstOrDefault(); |
| | | // 修改后的查询代码 |
| | | #endregion |
| | | var stockInfo = await _stockInfoRepository.Db.Queryable<DtStockInfo>() |
| | | .Includes(x => x.LocationInfo) |
| | | .Includes(x => x.StockInfoDetails) |
| | | .Where(x => x.ProductionLine == station.productLine) |
| | | .Where(x => x.AreaCode == "CWSC3" && x.IsFull == true) |
| | | // 增加对 LocationInfo 的空值检查 |
| | | .Where(x => x.LocationInfo.LocationStatus == (int)LocationEnum.InStock) |
| | | // 增加对 LocationInfo 的空值检查 |
| | | .WhereIF(!deviceCode.IsNullOrEmpty(), x => deviceCode.Contains(x.LocationInfo.RoadwayNo)) |
| | | .WhereIF(!materielCodes.IsNullOrEmpty(), x => x.StockInfoDetails.Any(y => materielCodes.Contains(y.MaterielCode))) |
| | | .OrderBy(x => x.OutboundTime) |
| | | .FirstAsync(); |
| | | //var stockInfo = await _stockInfoRepository.Db.Queryable<DtStockInfo>() |
| | | // .Includes(x => x.LocationInfo) |
| | | // .Includes(x => x.StockInfoDetails) |
| | | // .Where(x => x.ProductionLine == station.productLine) |
| | | // .Where(x => x.AreaCode == "CWSC3" && x.IsFull == true) |
| | | // // 增加对 LocationInfo 的空值检查 |
| | | // .Where(x => x.LocationInfo.LocationStatus == (int)LocationEnum.InStock) |
| | | // // 增加对 LocationInfo 的空值检查 |
| | | // .WhereIF(!deviceCode.IsNullOrEmpty(), x => deviceCode.Contains(x.LocationInfo.RoadwayNo)) |
| | | // .WhereIF(!materielCodes.IsNullOrEmpty(), x => x.StockInfoDetails.Any(y => materielCodes.Contains(y.MaterielCode))) |
| | | // .OrderBy(x => x.OutboundTime) |
| | | // .FirstAsync(); |
| | | |
| | | DtStockInfo stockInfo = null; |
| | | var stockInfoList = await _stockInfoRepository.Db.Queryable<DtStockInfo>() |
| | | .Includes(x => x.LocationInfo) |
| | | .Where(x => x.ProductionLine == station.productLine |
| | | && x.AreaCode == "CWSC3" |
| | | && x.IsFull == true |
| | | && x.LocationInfo.LocationStatus == (int)LocationEnum.InStock) |
| | | .WhereIF(!deviceCode.IsNullOrEmpty(), x => deviceCode.Contains(x.LocationInfo.RoadwayNo)) |
| | | .OrderBy(x => x.OutboundTime) |
| | | .ToListAsync(); |
| | | |
| | | foreach (var stock in stockInfoList) |
| | | { |
| | | var hasMatchingDetail = await _stockInfoRepository.Db.Queryable<DtStockInfoDetail>() |
| | | .Where(d => d.StockId == stock.Id && materielCodes.Contains(d.MaterielCode)) |
| | | .AnyAsync(); |
| | | |
| | | if (hasMatchingDetail) |
| | | { |
| | | stockInfo = stock; |
| | | } |
| | | } |
| | | if (stockInfo == null) throw new Exception($"库内{station.productLine}无满足条件的库存可出库"); |
| | | |
| | | DtLocationInfo locationInfo = _locationRepository.QueryFirst(x => x.AreaId == 5 && x.LocationCode == stockInfo.LocationCode); |