| | |
| | | using Model.ModelDto.PdaDto; |
| | | using SqlSugar; |
| | | using WMS.BLL.LogServer; |
| | | using WMS.DAL; |
| | | using WMS.Entity.BllAsnEntity; |
| | | using WMS.Entity.BllCheckEntity; |
| | | using WMS.Entity.BllSoEntity; |
| | | using WMS.Entity.Context; |
| | | using WMS.Entity.DataEntity; |
| | | using WMS.Entity.LogEntity; |
| | | using WMS.Entity.SysEntity; |
| | | using WMS.IBLL.IPdaServer; |
| | | |
| | |
| | | } |
| | | |
| | | //获取要盘点的箱码信息(盘点记录中数据) |
| | | public List<StockCheckLogDto> GetStockCheckLogList(string crNo, string crDetail, string palletNo, string boxNo) |
| | | public List<StockCheckLogDto> GetStockCheckLogList(string crNo, string crDetail, string palletNo, string boxNo, string isContinue) |
| | | { |
| | | try |
| | | { |
| | |
| | | |
| | | var detail = crDetail.Split("-"); |
| | | var sku = detail[0]; |
| | | //判断是否为无码物料 |
| | | var skuinfo = Db.Queryable<SysMaterials>().First(m => m.IsDel == "0" && m.SkuNo == sku); |
| | | //判断是否存在物料消息 |
| | | if (skuinfo == null) |
| | | { |
| | | throw new Exception("托盘码不能为空"); |
| | | } |
| | | int isQtySku = 0; |
| | | if (skuinfo.Type == "4" && isContinue == "1") |
| | | { |
| | | isQtySku = 1; |
| | | } |
| | | var lotNo = detail[1]; |
| | | var list = Db.Queryable<BllStockCheckLog>().Where(m => m.IsDel == "0" && m.CRNo == crNo); |
| | | //var deList= Db.Queryable<BllStockCheckDetail>().Where(m => m.IsDel == "0" && m.SkuNo == sku && m.LotNo == lotNo && m.PalletNo == palletNo); |
| | |
| | | //{ |
| | | // throw new Exception("未查询到托盘上的盘点物料批次信息"); |
| | | //} |
| | | |
| | | list = list.Where(m => m.SkuNo == sku && m.LotNo == lotNo && m.PalletNo == palletNo); |
| | | if (!string.IsNullOrWhiteSpace(boxNo)) |
| | | { |
| | | list = list.Where(m => m.BoxNo == boxNo); |
| | | } |
| | | |
| | | var data = list.Select(m => new StockCheckLogDto() |
| | | List<StockCheckLogDto> data = new List<StockCheckLogDto>(); |
| | | //判断是否为无码物料 |
| | | if (isQtySku == 1) |
| | | { |
| | | BoxNo = m.BoxNo, |
| | | BoxNo3 = m.BoxNo3, |
| | | SkuNo = m.SkuNo, |
| | | SkuName = m.SkuName, |
| | | LotNo = m.LotNo, |
| | | Qty = m.Qty, |
| | | CheckResult = m.CheckResult, |
| | | //获取库存信息 |
| | | var stockDetail = Db.Queryable<DataStockDetail>().First(a => a.IsDel == "0" && a.Status == "3" && a.SkuNo == sku && a.PalletNo == palletNo); |
| | | |
| | | }).ToList(); |
| | | var model = new StockCheckLogDto() |
| | | { |
| | | PalletNo = palletNo, |
| | | SkuNo = sku, |
| | | Qty = (int?)stockDetail.Qty, |
| | | CheckResult = 4, |
| | | }; |
| | | |
| | | data.Add(model); |
| | | |
| | | } |
| | | else |
| | | { |
| | | data = list.Select(m => new StockCheckLogDto() |
| | | { |
| | | BoxNo = m.BoxNo, |
| | | BoxNo3 = m.BoxNo3, |
| | | SkuNo = m.SkuNo, |
| | | SkuName = m.SkuName, |
| | | LotNo = m.LotNo, |
| | | Qty = m.Qty, |
| | | CheckResult = m.CheckResult, |
| | | |
| | | }).ToList(); |
| | | |
| | | } |
| | | |
| | | return data; |
| | | |
| | | } |
| | | catch (Exception e) |
| | | { |
| | |
| | | } |
| | | } |
| | | |
| | | public void CrSetCheck(string crNo, string crDetail, string palletNo, string boxNo, string boxNo3, string result, int? qty, int userId) |
| | | public void CrSetCheck(string crNo, string crDetail, string palletNo, string boxNo, string boxNo3, string result, int? qty, string isContinue, int userId) |
| | | { |
| | | try |
| | | { |
| | |
| | | //盘点记录 |
| | | var checkLog = Db.Queryable<BllStockCheckLog>().Where(m => |
| | | m.IsDel == "0" && m.CRNo == crNo && m.PalletNo == palletNo && m.SkuNo == sku && m.LotNo == lotNo && m.CheckResult == null); |
| | | |
| | | var time = DateTime.Now; |
| | | //正常 |
| | | if (result == "0") |
| | | { |
| | | if (!string.IsNullOrWhiteSpace(boxNo)) |
| | |
| | | checkLog = checkLog.Where(m => m.BoxNo3 == boxNo3); |
| | | } |
| | | |
| | | if (checkLog.Count() == 0) |
| | | if (checkLog.Count() == 0 && isContinue == "0") |
| | | { |
| | | throw new Exception("未查询到未盘点的箱支信息"); |
| | | } |
| | |
| | | { |
| | | if (l.CheckResult != null) |
| | | { |
| | | continue; |
| | | continue; |
| | | } |
| | | l.RealQty = l.Qty; |
| | | l.CheckResult = 0; |
| | |
| | | checkDetail.RealQty = 0; |
| | | } |
| | | checkDetail.RealQty += num; |
| | | checkDetail.CheckResult = 0; |
| | | //if (checkDetail.CheckResult == null || checkDetail.CheckResult == 0) |
| | | //{ |
| | | // checkDetail.CheckResult = 0; |
| | |
| | | Db.Updateable(checkDetail).ExecuteCommand(); |
| | | Db.Updateable(list).ExecuteCommand(); |
| | | } |
| | | //盘亏 |
| | | else if (result == "1") |
| | | { |
| | | if (!string.IsNullOrWhiteSpace(boxNo)) |
| | |
| | | checkLog = checkLog.Where(m => m.BoxNo3 == boxNo3); |
| | | } |
| | | |
| | | if (checkLog.Count() == 0) |
| | | if (checkLog.Count() == 0 && isContinue == "0") |
| | | { |
| | | throw new Exception("未查询到箱支信息"); |
| | | } |
| | | |
| | | // |
| | | if (isContinue == "1") |
| | | { |
| | | if (qty == null || qty <= 0) |
| | | { |
| | | throw new Exception("数量盘点时、盘亏数量不能为空且需大于0"); |
| | | } |
| | | } |
| | | |
| | | |
| | | var list = checkLog.ToList(); |
| | | var num = 0; |
| | |
| | | checkDetail.RealQty = 0; |
| | | } |
| | | checkDetail.RealQty += num; |
| | | //checkDetail.CheckResult = 1; |
| | | if (isContinue == "1") |
| | | { |
| | | checkDetail.RealQty = qty; |
| | | } |
| | | checkDetail.CheckResult = 1; |
| | | var checkInfo = Db.Queryable<BllStockCheckLog>().First(m => |
| | | m.IsDel == "0" && m.CRNo == crNo && m.PalletNo == palletNo && m.SkuNo == sku && m.LotNo == lotNo); |
| | | checkInfo.RealQty = qty; |
| | | checkInfo.CheckResult = 1; |
| | | |
| | | checkInfo.CheckUserId = userId; |
| | | checkInfo.CheckDate = time; |
| | | |
| | | checkInfo.UpdateUser = userId; |
| | | checkInfo.UpdateTime = time; |
| | | Db.Updateable(checkInfo).ExecuteCommand(); |
| | | Db.Updateable(checkDetail).ExecuteCommand(); |
| | | Db.Updateable(list).ExecuteCommand(); |
| | | } |
| | | //盘盈 |
| | | else if (result == "2") |
| | | { |
| | | if (string.IsNullOrWhiteSpace(boxNo) || string.IsNullOrWhiteSpace(boxNo3)) |
| | | if (isContinue == "0") |
| | | { |
| | | throw new Exception("盘盈时箱码与支码不能为空"); |
| | | if (string.IsNullOrWhiteSpace(boxNo) || string.IsNullOrWhiteSpace(boxNo3)) |
| | | { |
| | | throw new Exception("盘盈时箱码与支码不能为空"); |
| | | } |
| | | } |
| | | |
| | | if (qty == null || qty <= 0) |
| | | { |
| | | throw new Exception("盘盈时数量不能为空且需大于0"); |
| | | } |
| | | |
| | | var count = Db.Queryable<DataBoxInfo>() |
| | | .Count(m => m.IsDel == "0" && m.BoxNo == boxNo && m.BoxNo3 == boxNo3); |
| | | var count2 = Db.Queryable<BllStockCheckLog>() |
| | | .Count(m => m.IsDel == "0" && m.BoxNo == boxNo && m.BoxNo3 == boxNo3); |
| | | if (count > 0 || count2 > 0) |
| | | if (isContinue == "0") |
| | | { |
| | | throw new Exception("当前库存中已存在该箱支信息"); |
| | | var count = Db.Queryable<DataBoxInfo>() |
| | | .Count(m => m.IsDel == "0" && m.BoxNo == boxNo && m.BoxNo3 == boxNo3); |
| | | var count2 = Db.Queryable<BllStockCheckLog>() |
| | | .Count(m => m.IsDel == "0" && m.BoxNo == boxNo && m.BoxNo3 == boxNo3); |
| | | if (count > 0 || count2 > 0) |
| | | { |
| | | throw new Exception("当前库存中已存在该箱支信息"); |
| | | } |
| | | } |
| | | var crLog = new BllStockCheckLog() |
| | | BllStockCheckLog crLog = new BllStockCheckLog(); |
| | | if (isContinue == "0") |
| | | { |
| | | CRNo = crNo, |
| | | PalletNo = palletNo, |
| | | BoxNo = boxNo, |
| | | BoxNo2 = null, |
| | | BoxNo3 = boxNo3, |
| | | Qty = qty, |
| | | SkuNo = checkDetail.SkuNo, |
| | | SkuName = checkDetail.SkuName, |
| | | Standard = checkDetail.Standard, |
| | | LotNo = checkDetail.LotNo, |
| | | LotText = checkDetail.LotText, |
| | | SupplierLot = checkDetail.SupplierLot, |
| | | crLog = new BllStockCheckLog() |
| | | { |
| | | CRNo = crNo, |
| | | PalletNo = palletNo, |
| | | BoxNo = boxNo, |
| | | BoxNo2 = null, |
| | | BoxNo3 = boxNo3, |
| | | Qty = qty, |
| | | SkuNo = checkDetail.SkuNo, |
| | | SkuName = checkDetail.SkuName, |
| | | Standard = checkDetail.Standard, |
| | | LotNo = checkDetail.LotNo, |
| | | LotText = checkDetail.LotText, |
| | | SupplierLot = checkDetail.SupplierLot, |
| | | |
| | | RealQty = qty, |
| | | CheckResult = 2, |
| | | CheckDate = time, |
| | | CheckUserId = userId, |
| | | RealQty = qty, |
| | | CheckResult = 2, |
| | | CheckDate = time, |
| | | CheckUserId = userId, |
| | | |
| | | CreateUser = userId, |
| | | CreateTime = time |
| | | }; |
| | | if (checkDetail.RealQty == null) |
| | | CreateUser = userId, |
| | | CreateTime = time |
| | | }; |
| | | } |
| | | else |
| | | { |
| | | var checkInfo = Db.Queryable<BllStockCheckLog>().First(m => |
| | | m.IsDel == "0" && m.CRNo == crNo && m.PalletNo == palletNo && m.SkuNo == sku && m.LotNo == lotNo); |
| | | checkInfo.RealQty = qty; |
| | | checkInfo.CheckResult = 2; |
| | | |
| | | checkInfo.CheckUserId = userId; |
| | | checkInfo.CheckDate = time; |
| | | |
| | | checkInfo.UpdateUser = userId; |
| | | checkInfo.UpdateTime = time; |
| | | Db.Updateable(checkInfo).ExecuteCommand(); |
| | | } |
| | | |
| | | if (checkDetail.RealQty == null && isContinue == "0") |
| | | { |
| | | checkDetail.RealQty = 0; |
| | | } |
| | | checkDetail.RealQty += qty; |
| | | //checkDetail.CheckResult = 1; |
| | | if (isContinue == "1") |
| | | { |
| | | checkDetail.RealQty = qty; |
| | | } |
| | | checkDetail.CheckResult = 2; |
| | | Db.Updateable(checkDetail).ExecuteCommand(); |
| | | Db.Insertable(crLog).ExecuteCommand(); |
| | | if (isContinue == "0") |
| | | { |
| | | Db.Insertable(crLog).ExecuteCommand(); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | Db.RollbackTran(); |
| | | throw new Exception("盘点结果不符,请核实!"); |
| | | } |
| | | var checkLogNum = Db.Queryable<BllStockCheckLog>().Where(m => m.IsDel == "0" && m.CRNo == crNo && m.PalletNo == palletNo && m.SkuNo == sku && m.LotNo == lotNo); |
| | |
| | | { |
| | | str += " and PalletNo like @palletno"; |
| | | } |
| | | |
| | | |
| | | //排序 |
| | | str += " order by LotNo,LocatNo,PalletNo"; |
| | | List<DataStockDetail> stockList = Db.Ado.SqlQuery<DataStockDetail>(str, new |
| | |
| | | { |
| | | throw new Exception("托盘号不能为空"); |
| | | } |
| | | var detail = Db.Queryable<DataStockDetail>().Where(m => m.IsDel == "0" && m.PalletNo == palletNo).Select(m=>m.Id).ToList(); |
| | | var detail = Db.Queryable<DataStockDetail>().Where(m => m.IsDel == "0" && m.PalletNo == palletNo).Select(m => m.Id).ToList(); |
| | | var info = Db.Queryable<DataBoxInfo>().Where(m => m.IsDel == "0" && detail.Contains(m.StockDetailId)) |
| | | .GroupBy(m => m.BoxNo).Select(a => new PdaPalletNoCheckDto |
| | | { |
| | |
| | | }).ToList(); |
| | | return info; |
| | | } |
| | | catch(Exception e) |
| | | catch (Exception e) |
| | | { |
| | | throw new Exception(e.Message); |
| | | } |
| | |
| | | { |
| | | throw new Exception("箱码不能为空"); |
| | | } |
| | | |
| | | |
| | | var info = Db.Queryable<DataBoxInfo>().Where(m => m.IsDel == "0" && m.BoxNo == boxNo) |
| | | .GroupBy(m => new{m.BoxNo,m.SkuNo,m.SkuName,m.LotNo}).Select(a => new PdaPalletNoCheckDto |
| | | .GroupBy(m => new { m.BoxNo, m.SkuNo, m.SkuName, m.LotNo }).Select(a => new PdaPalletNoCheckDto |
| | | { |
| | | BoxNo = a.BoxNo, |
| | | SkuNo = a.SkuNo, |
| | |
| | | LotNo = a.LotNo, |
| | | Qty = SqlFunc.AggregateSum(a.Qty) |
| | | }).ToList(); |
| | | if (info.Count>1) |
| | | if (info.Count > 1) |
| | | { |
| | | throw new Exception("当前箱码查询出多条物料或批次信息,请核实"); |
| | | } |
| | |
| | | } |
| | | |
| | | //解绑原托盘绑定新托盘 |
| | | public void SaveUnbind(string palletNo,string boxNo,string palletNoNew,int userId) |
| | | public void SaveUnbind(string palletNo, string boxNo, string palletNoNew, int userId) |
| | | { |
| | | try |
| | | { |
| | |
| | | throw new Exception("原托盘上未查到箱支明细,请核实"); |
| | | } |
| | | //库存明细id |
| | | var infoIds = infos.GroupBy(m => m.StockDetailId).Select(a =>a.StockDetailId).ToList(); |
| | | var infoIds = infos.GroupBy(m => m.StockDetailId).Select(a => a.StockDetailId).ToList(); |
| | | if (infoIds.Count == 0) |
| | | { |
| | | throw new Exception("未查询到当前箱码信息,请核实"); |
| | |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | #endregion |
| | | } |
| | | if (!newPalletHaveGoods)//新托盘上没有物品 |
| | |
| | | } |
| | | var stockDetail2 = stockDetailList.FirstOrDefault(w => w.SkuNo == stockDetail1.SkuNo && w.LotNo == stockDetail1.LotNo); |
| | | |
| | | var stId = 0; |
| | | var stId = 0; |
| | | if (stockDetail2 == null) //添加-新托盘上没有同物料同批次物品 |
| | | { |
| | | //新托盘添加库存明细 |
| | |
| | | { |
| | | try |
| | | { |
| | | var models = Db.Queryable<DataStockDetail>().First(w => w.IsDel == "0" && w.PalletNo == palletNo); |
| | | if (models == null) |
| | | { |
| | | throw new Exception("托盘库存信息不存在,请检查!"); |
| | | } |
| | | if (string.IsNullOrEmpty(models.LocatNo)) |
| | | { |
| | | throw new Exception("托盘储位信息不存在,请检查!"); |
| | | } |
| | | if (models.WareHouseNo != "W02") |
| | | { |
| | | throw new Exception("该托盘未在平库内,请检查!"); |
| | | } |
| | | var storageLocat = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.LocatNo == models.LocatNo); |
| | | if (storageLocat == null) |
| | | { |
| | | throw new Exception("储位信息不存在,请检查!"); |
| | | } |
| | | var storageArea = new List<SysStorageArea>(); |
| | | if (storageLocat.AreaNo.Contains("B0")) |
| | | if (string.IsNullOrEmpty(palletNo)) |
| | | { |
| | | storageArea = Db.Queryable<SysStorageArea>().Where(w => w.AreaNo.Contains("B0")).ToList(); |
| | | storageArea = Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.WareHouseNo == "W02").OrderBy(o=>o.AreaNo).ToList(); |
| | | } |
| | | else |
| | | { |
| | | storageArea = Db.Queryable<SysStorageArea>().Where(w => w.AreaNo.Contains("B1")).ToList(); |
| | | } |
| | | var models = Db.Queryable<DataStockDetail>().First(w => w.IsDel == "0" && w.PalletNo == palletNo); |
| | | if (models == null) |
| | | { |
| | | throw new Exception("托盘库存信息不存在,请检查!"); |
| | | } |
| | | if (string.IsNullOrEmpty(models.LocatNo)) |
| | | { |
| | | throw new Exception("托盘储位信息不存在,请检查!"); |
| | | } |
| | | if (models.WareHouseNo != "W02") |
| | | { |
| | | throw new Exception("该托盘未在平库内,请检查!"); |
| | | } |
| | | var storageLocat = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.LocatNo == models.LocatNo); |
| | | if (storageLocat == null) |
| | | { |
| | | throw new Exception("储位信息不存在,请检查!"); |
| | | } |
| | | |
| | | if (storageLocat.AreaNo.Contains("B0")) |
| | | { |
| | | storageArea = Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.AreaNo.Contains("B0") && w.WareHouseNo == "W02").OrderBy(o => o.AreaNo).ToList(); |
| | | } |
| | | else |
| | | { |
| | | storageArea = Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.AreaNo.Contains("B1") && w.WareHouseNo == "W02").OrderBy(o => o.AreaNo).ToList(); |
| | | } |
| | | } |
| | | return storageArea; |
| | | } |
| | | catch (Exception ex) |
| | |
| | | } |
| | | |
| | | /// <summary> |
| | | /// agv转运呼叫小车-开发未完成待确认 |
| | | /// agv转运呼叫小车 |
| | | /// </summary> |
| | | /// <param name="palletNo"></param> |
| | | /// <param name="areaNo"></param> |
| | |
| | | { |
| | | throw new Exception("请选择目标区域或入库口!"); |
| | | } |
| | | if (!string.IsNullOrEmpty(areaNo) && !string.IsNullOrEmpty(ruku)) |
| | | { |
| | | throw new Exception("目标区域和入库口不能同时选择!"); |
| | | } |
| | | try |
| | | { |
| | | string EndLocat = string.Empty;//目标位置 |
| | | |
| | | var log = Db.Queryable<LogTask>().First(w => w.IsDel == "0" && w.PalletNo == palletNo && (w.Status == "0" || w.Status == "1")); |
| | | if (log != null) |
| | | { |
| | | throw new Exception("该托盘已有小车等待执行或正在执行的任务!"); |
| | | } |
| | | var stockDetail = Db.Queryable<DataStockDetail>().First(w => w.IsDel == "0" && w.PalletNo == palletNo); |
| | | if (stockDetail == null) |
| | | { |
| | | throw new Exception("托盘库存信息不存在,请检查!"); |
| | | throw new Exception("托盘上物料库存明细信息不存在,请检查!"); |
| | | } |
| | | if (!string.IsNullOrEmpty(areaNo)) |
| | | { |
| | | var storageArea = Db.Queryable<SysStorageArea>().First(w => w.IsDel == "0" && w.AreaNo == areaNo); |
| | | if (storageArea == null) |
| | | { |
| | | throw new Exception("所选区域信息不存在,请检查!"); |
| | | } |
| | | EndLocat = GetLocat(areaNo, stockDetail.SkuNo, stockDetail.LotNo,palletNo); |
| | | } |
| | | else |
| | | { |
| | | EndLocat = ruku; |
| | | } |
| | | var stock = Db.Queryable<DataStock>().First(w => w.IsDel == "0" && w.SkuNo == stockDetail.SkuNo && w.LotNo == stockDetail.LotNo); |
| | | if (stock == null) |
| | | { |
| | | throw new Exception("托盘上物料库存信息不存在,请检查!"); |
| | | } |
| | | if (string.IsNullOrEmpty(stockDetail.LocatNo)) |
| | | { |
| | |
| | | { |
| | | throw new Exception("该托盘未在平库内,请检查!"); |
| | | } |
| | | //起始储位信息 |
| | | var storageLocat = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.LocatNo == stockDetail.LocatNo); |
| | | if (storageLocat == null) |
| | | { |
| | | throw new Exception("储位信息不存在,请检查!"); |
| | | } |
| | | //目标储位信息 |
| | | var storageLocatEnd = new SysStorageLocat(); |
| | | if (!string.IsNullOrEmpty(areaNo)) |
| | | { |
| | | storageLocatEnd = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.LocatNo == EndLocat && w.Flag == "0" && w.Status == "0"); |
| | | if (storageLocatEnd == null) |
| | | { |
| | | throw new Exception("目标储位信息不存在,请检查!"); |
| | | } |
| | | } |
| | | |
| | | //开启事务 |
| | | Db.BeginTran(); |
| | | |
| | | //添加出库任务 |
| | | var taskNo = new Common().GetMaxNo("TK"); |
| | | var exTask = new LogTask |
| | | { |
| | | TaskNo = taskNo, |
| | | Sender = "WMS", |
| | | Receiver = "AGV", |
| | | IsSuccess = 0, //是否下发成功 0失败 1成功 |
| | | |
| | | StartLocat = stockDetail.LocatNo,//起始位置 |
| | | EndLocat = EndLocat,//目标位置 |
| | | PalletNo = palletNo,//托盘码 |
| | | Msg = string.Format("转运任务:{0}=>>{1}", stockDetail.LocatNo, EndLocat), |
| | | IsSend = 1,//是否可再次下发 |
| | | IsCancel = 1,//是否可取消 |
| | | IsFinish = 1,//是否可完成 |
| | | Type = "2",//任务类型 0 入库任务 1 出库任务 2 移库任务 |
| | | Status = "0",//任务状态0:等待执行1正在执行2执行完成 |
| | | OrderType = "3",//0 入库单 1 出库单 2 盘点单 3 移库单 |
| | | |
| | | CreateTime = DateTime.Now |
| | | }; |
| | | Db.Insertable(exTask).ExecuteCommand(); |
| | | |
| | | //修改库存明细信息 |
| | | stockDetail.WareHouseNo = ""; |
| | | stockDetail.RoadwayNo = ""; |
| | | stockDetail.AreaNo = ""; |
| | | stockDetail.LocatNo = ""; |
| | | |
| | | stockDetail.Status = "4";//移库锁定 |
| | | stockDetail.LockQty = stockDetail.Qty;//锁定库存数量 |
| | | Db.Updateable(stockDetail).ExecuteCommand(); |
| | | //修改储位地址状态 |
| | | storageLocat.Status = "0";//空储位 |
| | | //修改库存信息 |
| | | stock.LockQty += (decimal)stockDetail.Qty; |
| | | Db.Updateable(stock).ExecuteCommand(); |
| | | |
| | | //修改起始储位地址状态 |
| | | storageLocat.Status = "5";//0:空储位 1:有物品 2:入库中 3:出库中 4:移入中 5:移出中 |
| | | Db.Updateable(storageLocat).ExecuteCommand(); |
| | | |
| | | //修改目标储位地址状态 |
| | | if (storageLocatEnd != null) |
| | | { |
| | | storageLocatEnd.Status = "4";//0:空储位 1:有物品 2:入库中 3:出库中 4:移入中 5:移出中 |
| | | Db.Updateable(storageLocatEnd).ExecuteCommand(); |
| | | } |
| | | //添加操作日志记录 |
| | | var k = new OperationCrServer().AddLogOperationCr("PDA模块", "AGV转运", palletNo, "移库", $"PDA呼叫小车对托盘号:{palletNo}发起转运", userId); |
| | | //提交事务 |
| | | Db.CommitTran(); |
| | | |
| | | #region 呼叫小车代码 |
| | | |
| | | #endregion |
| | | //提交事务 |
| | | Db.CommitTran(); |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | |
| | | } |
| | | } |
| | | /// <summary> |
| | | /// agv转运呼叫小车取货-开发未完成待确认 |
| | | /// agv转运呼叫小车取货 |
| | | /// </summary> |
| | | /// <param name="soNo"></param> |
| | | /// <param name="palletNo"></param> |
| | |
| | | { |
| | | throw new Exception("请选择出库单据!"); |
| | | } |
| | | if (string.IsNullOrEmpty(palletNo)) |
| | | { |
| | | throw new Exception("请扫描托盘条码!"); |
| | | } |
| | | if (string.IsNullOrEmpty(areaNo)) |
| | | { |
| | | throw new Exception("请选择目标区域!"); |
| | | } |
| | | try |
| | | { |
| | | //开启事务 |
| | | Db.BeginTran(); |
| | | //出库单信息 |
| | | var notice = Db.Queryable<BllExportNotice>().First(w => w.IsDel == "0" && w.SONo == soNo); |
| | | if (notice == null) |
| | | { |
| | | throw new Exception("出库单据信息不存在,请检查!"); |
| | | } |
| | | var allot = Db.Queryable<BllExportAllot>().First(w => w.IsDel == "0" && w.SONo == soNo && w.PalletNo == palletNo); |
| | | if (allot == null) |
| | | //目标区域信息 |
| | | var storageArea = Db.Queryable<SysStorageArea>().First(w => w.IsDel == "0" && w.AreaNo == areaNo); |
| | | if (storageArea == null) |
| | | { |
| | | throw new Exception("该托盘出库分配信息不存在,请检查!"); |
| | | throw new Exception("所选区域信息不存在,请检查!"); |
| | | } |
| | | var stockDetail = Db.Queryable<DataStockDetail>().First(w => w.IsDel == "0" && w.PalletNo == palletNo); |
| | | if (stockDetail == null) |
| | | List<DataStockDetail> stockDetailList = new List<DataStockDetail>();//需要的托盘明细 |
| | | if (!string.IsNullOrEmpty(palletNo))//单托盘叫货 |
| | | { |
| | | throw new Exception("托盘库存信息不存在,请检查!"); |
| | | stockDetailList = Db.Queryable<DataStockDetail>().Where(w => w.IsDel == "0" && w.PalletNo == palletNo).ToList(); |
| | | } |
| | | if (string.IsNullOrEmpty(stockDetail.LocatNo)) |
| | | else//整个出库单叫货 |
| | | { |
| | | throw new Exception("托盘储位信息不存在,请检查!"); |
| | | string sqlStr = $"select * from DataStockDetail where PalletNo in (select PalletNo from BllExportAllot where IsDel='0' and SONo='{soNo}')"; |
| | | stockDetailList = Db.Ado.SqlQuery<DataStockDetail>(sqlStr).ToList(); |
| | | } |
| | | if (stockDetail.WareHouseNo != "W02") |
| | | if (stockDetailList.Count<=0) |
| | | { |
| | | throw new Exception("该托盘未在平库内,请检查!"); |
| | | throw new Exception("托盘明细不存在,请检查!"); |
| | | } |
| | | var storageLocat = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.LocatNo == stockDetail.LocatNo); |
| | | if (storageLocat == null) |
| | | { |
| | | throw new Exception("储位信息不存在,请检查!"); |
| | | } |
| | | //开启事务 |
| | | Db.BeginTran(); |
| | | //修改库存明细信息 |
| | | stockDetail.WareHouseNo = ""; |
| | | stockDetail.RoadwayNo = ""; |
| | | stockDetail.AreaNo = ""; |
| | | stockDetail.LocatNo = ""; |
| | | |
| | | Db.Updateable(stockDetail).ExecuteCommand(); |
| | | //修改储位地址状态 |
| | | storageLocat.Status = "0";//空储位 |
| | | var log = Db.Queryable<LogTask>().Where(w => w.IsDel == "0" && (w.Status == "0" || w.Status == "1"));//任务表 |
| | | var storageLocat = Db.Queryable<SysStorageLocat>().Where(w => w.IsDel == "0");//储位表 |
| | | var stock = Db.Queryable<DataStock>().Where(w => w.IsDel == "0");//库存总表 |
| | | string EndLocat = string.Empty;//目标位置 |
| | | string hasLocatNoList = string.Empty;//已分配的储位 |
| | | foreach (var item in stockDetailList) |
| | | { |
| | | //任务信息 |
| | | var logInfo = log.First(w =>w.PalletNo == item.PalletNo); |
| | | if (logInfo != null) |
| | | { |
| | | throw new Exception($"托盘号:{item.PalletNo}已有小车等待执行或正在执行的任务!"); |
| | | } |
| | | if (string.IsNullOrEmpty(item.LocatNo)) |
| | | { |
| | | throw new Exception($"托盘号:{item.PalletNo}的储位信息不存在,请检查!"); |
| | | } |
| | | if (item.WareHouseNo != "W02") |
| | | { |
| | | throw new Exception($"托盘号:{item.PalletNo}未在平库内,请检查!"); |
| | | } |
| | | //起始储位信息 |
| | | var storageLocatBegin = storageLocat.First(w => w.LocatNo == item.LocatNo); |
| | | if (storageLocat == null) |
| | | { |
| | | throw new Exception($"托盘号:{item.PalletNo}所在的储位信息不存在,请检查!"); |
| | | } |
| | | //获取目标储位 |
| | | EndLocat = GetLocat(areaNo, item.SkuNo, item.LotNo, palletNo); |
| | | if (string.IsNullOrEmpty(EndLocat)) |
| | | { |
| | | throw new Exception("分配目标储位失败,请检查!"); |
| | | } |
| | | if (string.IsNullOrEmpty(hasLocatNoList)) |
| | | { |
| | | hasLocatNoList = EndLocat; |
| | | } |
| | | else |
| | | { |
| | | hasLocatNoList = hasLocatNoList + "," + EndLocat; |
| | | } |
| | | //目标储位信息 |
| | | var storageLocatEnd = storageLocat.First(w => w.LocatNo == EndLocat && w.Flag == "0" && w.Status == "0"); |
| | | if (storageLocatEnd == null) |
| | | { |
| | | throw new Exception("目标储位信息不存在,请检查!"); |
| | | } |
| | | |
| | | Db.Updateable(storageLocat).ExecuteCommand(); |
| | | //添加出库任务 |
| | | var taskNo = new Common().GetMaxNo("TK"); |
| | | var exTask = new LogTask |
| | | { |
| | | TaskNo = taskNo, |
| | | Sender = "WMS", |
| | | Receiver = "AGV", |
| | | IsSuccess = 0, //是否下发成功 0失败 1成功 |
| | | Msg = string.Format("转运任务:{0}=>>{1}", item.LocatNo, EndLocat), |
| | | StartLocat = item.LocatNo,//起始位置 |
| | | EndLocat = EndLocat,//目标位置 |
| | | PalletNo = palletNo,//托盘码 |
| | | IsSend = 1,//是否可再次下发 |
| | | IsCancel = 1,//是否可取消 |
| | | IsFinish = 1,//是否可完成 |
| | | Type = "2",//任务类型 0 入库任务 1 出库任务 2 移库任务 |
| | | Status = "0",//任务状态0:等待执行1正在执行2执行完成 |
| | | OrderType = "3",//0 入库单 1 出库单 2 盘点单 3 移库单 |
| | | |
| | | CreateTime = DateTime.Now |
| | | }; |
| | | Db.Insertable(exTask).ExecuteCommand(); |
| | | |
| | | //修改库存明细信息 |
| | | item.Status = "4";//移库锁定 |
| | | item.LockQty = item.Qty;//锁定库存数量 |
| | | Db.Updateable(item).ExecuteCommand(); |
| | | |
| | | //修改起始储位地址状态 |
| | | storageLocatBegin.Status = "5";//0:空储位 1:有物品 2:入库中 3:出库中 4:移入中 5:移出中 |
| | | Db.Updateable(storageLocatBegin).ExecuteCommand(); |
| | | //修改目标储位地址状态 |
| | | storageLocatEnd.Status = "4";//0:空储位 1:有物品 2:入库中 3:出库中 4:移入中 5:移出中 |
| | | Db.Updateable(storageLocatEnd).ExecuteCommand(); |
| | | |
| | | var stockInfo = stock.First(w => w.SkuNo == item.SkuNo && w.LotNo == item.LotNo); |
| | | //修改库存信息 |
| | | stockInfo.LockQty += (decimal)item.Qty;//锁定数量 |
| | | Db.Updateable(stockInfo).ExecuteCommand(); |
| | | } |
| | | if (string.IsNullOrEmpty(palletNo)) |
| | | { |
| | | //添加操作日志记录 |
| | | var k = new OperationCrServer().AddLogOperationCr("PDA模块", "AGV转运", palletNo, "移库", $"PDA呼叫小车对出库单:{soNo}下所有托盘发起转运", userId); |
| | | } |
| | | else |
| | | { |
| | | //添加操作日志记录 |
| | | var k = new OperationCrServer().AddLogOperationCr("PDA模块", "AGV转运", palletNo, "移库", $"PDA呼叫小车对托盘号:{palletNo}发起转运", userId); |
| | | } |
| | | //提交事务 |
| | | Db.CommitTran(); |
| | | |
| | | #region 呼叫小车代码 |
| | | |
| | | #endregion |
| | | //提交事务 |
| | | Db.CommitTran(); |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | |
| | | throw new Exception(ex.Message); |
| | | } |
| | | } |
| | | /// <summary> |
| | | /// 根据区域分配储位 |
| | | /// </summary> |
| | | /// <param name="areaNo"></param> |
| | | /// <param name="skuNo"></param> |
| | | /// <param name="lotNo"></param> |
| | | /// <returns></returns> |
| | | private string GetLocat(string areaNo,string skuNo,string lotNo,string palletNo,string hasLocatNoList="") |
| | | { |
| | | try |
| | | { |
| | | string endLocat = string.Empty;//目标储位 |
| | | //当然区域所有储位信息 |
| | | var storageLocatList = Db.Queryable<SysStorageLocat>().Where(w => w.WareHouseNo == "W02" && w.AreaNo == areaNo).ToList(); |
| | | //同区域同批次物料的储位信息 |
| | | List<string> locatList = Db.Queryable<DataStockDetail>().Where(w => w.IsDel == "0" && w.SkuNo == skuNo && w.LotNo == lotNo && w.WareHouseNo == "W02" && w.AreaNo == areaNo && w.PalletNo != palletNo) |
| | | .OrderByDescending(o=>o.LocatNo).Select(s=>s.LocatNo).Distinct().ToList(); |
| | | foreach (var item in locatList) |
| | | { |
| | | var locatInfo = storageLocatList.Where(w => w.LocatNo == item).First(); |
| | | |
| | | var locatInfo2 = storageLocatList.Where(w => w.IsDel == "0" && w.Status == "0" && w.Flag == "0" && w.LocatNo != locatInfo.LocatNo && w.Row == locatInfo.Row && !hasLocatNoList.Contains(w.LocatNo)) |
| | | .OrderByDescending(o => o.Column).First(); |
| | | if (locatInfo2 != null) |
| | | { |
| | | endLocat = locatInfo2.LocatNo; |
| | | } |
| | | } |
| | | if (string.IsNullOrEmpty(endLocat)) |
| | | { |
| | | var locatInfo3 = storageLocatList.Where(w => w.IsDel == "0" && w.Flag == "0" && w.Status == "0" && !hasLocatNoList.Contains(w.LocatNo)) |
| | | .OrderByDescending(m => m.Layer).OrderByDescending(m=>m.Column).OrderByDescending(m=> m.Row).First(); |
| | | |
| | | if (locatInfo3 != null) |
| | | { |
| | | endLocat = locatInfo3.LocatNo; |
| | | } |
| | | } |
| | | return endLocat; |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | throw new Exception(ex.Message); |
| | | } |
| | | } |
| | | #endregion |
| | | |
| | | } |