| | |
| | | } |
| | | } |
| | | |
| | | /// <summary> |
| | | /// 根据箱码获取标签箱码信息(车间入库-获取WMS生成的箱信息) |
| | | /// </summary> |
| | | /// <param name="model"></param> |
| | | /// <returns></returns> |
| | | public List<BoxInfoDto> GetWmsBoxInfos(string boxNo) |
| | | { |
| | | try |
| | | { |
| | | if (string.IsNullOrEmpty(boxNo)) |
| | | { |
| | | throw new Exception("请扫描外箱条码!"); |
| | | } |
| | | |
| | | string sqlString = $@"SELECT BoxNo, SkuNo, SkuName, LotNo, BitBoxMark, SUM(Qty) as Qty FROM BllBoxInfo |
| | | WHERE IsDel = '0' and Status='0' and BoxNo = '{boxNo}' |
| | | GROUP BY BoxNo,SkuNo,SkuName,LotNo,BitBoxMark; "; |
| | | var models = Db.Ado.SqlQuery<BoxInfoDto>(sqlString); |
| | | |
| | | if (models.Count != 0) |
| | | { |
| | | return models; |
| | | } |
| | | else |
| | | { |
| | | throw new Exception("没有查询到箱码信息"); |
| | | } |
| | | |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | throw ex; |
| | | } |
| | | } |
| | | |
| | | |
| | | public void ChejianIn(string palletNo,string boxNo,decimal qty,string areaNo,int userId) |
| | | { |
| | | try |
| | | { |
| | | #region MyRegion |
| | | |
| | | if (string.IsNullOrWhiteSpace(palletNo)) |
| | | { |
| | | throw new Exception("托盘号不能为空"); |
| | | } |
| | | if (string.IsNullOrWhiteSpace(boxNo)) |
| | | { |
| | | throw new Exception("箱号不能为空"); |
| | | } |
| | | if (qty<=0) |
| | | { |
| | | throw new Exception("数量不能小等0"); |
| | | } |
| | | var boxInfo = Db.Queryable<BllBoxInfo>().Where(m => m.IsDel == "0" && m.BoxNo == boxNo).ToList(); |
| | | if (boxInfo.Count == 0) |
| | | { |
| | | throw new Exception("未查询到当前箱号信息"); |
| | | } |
| | | var boxInfoOne = boxInfo.First(); |
| | | var pall = Db.Queryable<SysPallets>().First(m => m.IsDel == "0" && m.PalletNo == palletNo); |
| | | if (pall == null) |
| | | { |
| | | throw new Exception("未查询到当前托盘信息"); |
| | | } |
| | | #endregion |
| | | |
| | | //开启事务 |
| | | Db.BeginTran(); |
| | | //当前时间 |
| | | var comTime = DateTime.Now; |
| | | |
| | | #region 包装 |
| | | |
| | | var sku = Db.Queryable<SysMaterials>().First(m => m.IsDel == "0" && m.SkuNo == boxInfoOne.SkuNo); |
| | | var pack = Db.Queryable<SysPackag>().First(m => m.IsDel == "0" && m.PackagNo == sku.PackagNo); |
| | | |
| | | var pNum = 0;//托盘物品数量 |
| | | var bNum = 0;//箱码物品数量 |
| | | |
| | | //公共方法获取包装数量 |
| | | new Common().GetPackQtyInfo(pack.PackagNo, ref pNum, ref bNum); |
| | | |
| | | #endregion |
| | | |
| | | var msgStr = $"箱号为{boxNo}"; |
| | | var boxInfoList = new List<BllBoxInfo>(); |
| | | |
| | | |
| | | boxInfoList.AddRange(boxInfo); |
| | | |
| | | #region 库存明细 |
| | | |
| | | var area = Db.Queryable<SysStorageArea>().First(m => m.IsDel == "0" && m.AreaNo == areaNo); |
| | | if (area == null) |
| | | { |
| | | throw new Exception("入库区域不能为空"); |
| | | } |
| | | |
| | | var tags = "0"; |
| | | |
| | | // 判断库存明细是否已有此托盘信息 |
| | | var sd1 = Db.Queryable<DataStockDetail>().First(m => m.IsDel == "0" && m.SkuNo== boxInfoOne.SkuNo && m.LotNo == boxInfoOne.LotNo && m.PalletNo == palletNo); |
| | | var sdId1 = 0; |
| | | if (sd1 != null) |
| | | { |
| | | if (sd1.AreaNo!= areaNo) |
| | | { |
| | | throw new Exception("选择的区域与库存不同"); |
| | | } |
| | | sdId1 = sd1.Id; |
| | | // 库存已存在 更新数据 |
| | | sd1.Qty += qty; |
| | | sd1.CompleteTime = comTime; |
| | | sd1.UpdateUser = userId; |
| | | sd1.UpdateTime = comTime; |
| | | |
| | | Db.Updateable(sd1).ExecuteCommand(); |
| | | } |
| | | else |
| | | { |
| | | var sd2 = Db.Queryable<DataStockDetail>().Where(m => m.PalletNo == palletNo && m.IsDel == "0" && !string.IsNullOrWhiteSpace(m.AreaNo)); |
| | | if (sd2.Count(m=>m.AreaNo!= areaNo) > 0) |
| | | { |
| | | throw new Exception("当前托盘位置与选择的不同,请核实"); |
| | | } |
| | | // 库存不存在 插入数据 |
| | | sd1 = new DataStockDetail() |
| | | { |
| | | ASNNo = "", |
| | | LotNo = boxInfoOne.LotNo, |
| | | LotText = boxInfoOne.LotText, |
| | | SupplierLot = boxInfoOne.SupplierLot, |
| | | SkuNo = sku.SkuNo, |
| | | SkuName = sku.SkuName, |
| | | Standard = sku.Standard, |
| | | Qty = qty, |
| | | LockQty = 0, |
| | | FrozenQty = 0, |
| | | InspectQty = 0, |
| | | WareHouseNo = area.WareHouseNo,//所属仓库 |
| | | RoadwayNo = "",//所属巷道 |
| | | AreaNo = area.AreaNo,//所属区域 |
| | | LocatNo = "",//储位地址 |
| | | PalletNo = palletNo, |
| | | PalletTags = tags, |
| | | CompleteTime = comTime, |
| | | ProductionTime = boxInfoOne.ProductionTime, |
| | | ExpirationTime = boxInfoOne.ExpirationTime, |
| | | Status = "0", |
| | | InspectMark = boxInfoOne.InspectMark, |
| | | InspectStatus = sku.IsInspect, |
| | | BitPalletMark = "1", |
| | | PackagNo = sku.PackagNo, |
| | | |
| | | IsDel = "0", |
| | | CreateUser = 0, |
| | | CreateTime = comTime |
| | | }; |
| | | |
| | | //添加库存明细 |
| | | sdId1 = Db.Insertable(sd1).ExecuteReturnIdentity(); |
| | | } |
| | | #endregion |
| | | |
| | | // 更改箱支关系表 |
| | | decimal factQty = 0.00m;//托盘总数量 |
| | | |
| | | |
| | | //标签组托 |
| | | var boxGroup = boxInfo.GroupBy(m => m.BoxNo).ToList(); |
| | | foreach (var g in boxGroup) |
| | | { |
| | | decimal boxFullQty = 0;//箱内总数量 |
| | | foreach (var box in g) |
| | | { |
| | | if (box.BindNo != null && box.BindNo != 0) |
| | | { |
| | | continue; |
| | | } |
| | | |
| | | |
| | | box.PalletNo = palletNo; |
| | | box.Status = "2"; |
| | | |
| | | box.CompleteTime = comTime; |
| | | box.UpdateTime = comTime; |
| | | box.UpdateUser = userId; |
| | | |
| | | //box.Qty = box.Qty; |
| | | //box.BitBoxMark = box.Qty == box.FullQty ? "0" : "1"; |
| | | |
| | | factQty += box.Qty; |
| | | boxFullQty += box.Qty; |
| | | |
| | | #region 库存箱码明细 |
| | | var box2 = new DataBoxInfo() |
| | | { |
| | | StockDetailId = sdId1, |
| | | BoxNo = box.BoxNo, |
| | | BoxNo2 = box.BoxNo2, |
| | | BoxNo3 = box.BoxNo3, |
| | | PalletNo = box.PalletNo, |
| | | PalletNo2 = box.PalletNo2, |
| | | PalletNo3 = box.PalletNo3, |
| | | Qty = box.Qty, |
| | | FullQty = box.FullQty, |
| | | Status = "2",//0:未组托 1:已组托 2:已入库 3:已出库 4:已分配 5:已拣货 |
| | | LotNo = box.LotNo, |
| | | LotText = box.LotText, |
| | | SkuNo = box.SkuNo, |
| | | SkuName = box.SkuName, |
| | | Standard = sku.Standard, |
| | | ProductionTime = box.ProductionTime, |
| | | SupplierLot = box.SupplierLot, |
| | | InspectStatus = sku.IsInspect, |
| | | InspectMark = box.InspectMark, |
| | | BitBoxMark = box.BitBoxMark, |
| | | ExpirationTime = box.ExpirationTime, |
| | | |
| | | CreateUser = 0, |
| | | CreateTime = comTime |
| | | }; |
| | | //添加库存箱码明细 |
| | | Db.Insertable(box2).ExecuteCommand(); |
| | | #endregion |
| | | } |
| | | if (boxFullQty > bNum) |
| | | { |
| | | throw new Exception($"绑定失败,{g.Key}箱码绑定数量大于该物品包装数量!"); |
| | | } |
| | | } |
| | | //更改箱支关系表信息 |
| | | Db.Updateable(boxInfoList).ExecuteCommand(); |
| | | |
| | | |
| | | #region 库存 |
| | | var dataStock = Db.Queryable<DataStock>().First(m => m.IsDel == "0" && m.SkuNo == sku.SkuNo && m.LotNo == boxInfoOne.LotNo); |
| | | if (dataStock != null) |
| | | { |
| | | dataStock.Qty += factQty; |
| | | Db.Updateable(dataStock).ExecuteCommand(); |
| | | } |
| | | else |
| | | { |
| | | var stock = new DataStock() |
| | | { |
| | | SkuNo = sku.SkuNo, |
| | | SkuName = sku.SkuName, |
| | | Standard = sku.Standard, |
| | | LotNo = boxInfoOne.LotNo, |
| | | LotText = boxInfoOne.LotText, |
| | | Qty = qty, |
| | | LockQty = 0, |
| | | FrozenQty = 0, |
| | | IsSampling = "0", |
| | | IsDel = "0", |
| | | CreateUser = userId, |
| | | CreateTime = comTime |
| | | }; |
| | | Db.Insertable(stock).ExecuteCommand(); |
| | | } |
| | | #endregion |
| | | |
| | | // 更改托盘使用状态 |
| | | var sqlStr = $"update SysPallets set Status = '1' where PalletNo = '{palletNo}';"; |
| | | ////添加托盘记录表数据 |
| | | //sqlStr += $"insert into LogPalletTrack values('{palletNo}','{boxNo}','组盘','0',getDate(),{userId},NULL,NULL);"; |
| | | //Db.Ado.ExecuteCommand(sqlStr); |
| | | new OperationASNServer().AddLogOperationAsn("PDA模块", "车间入库", boxNo, "添加", $"添加了托盘码为:{palletNo}、{msgStr}的入库信息", userId); |
| | | |
| | | //提交事务 |
| | | Db.CommitTran(); |
| | | |
| | | } |
| | | catch (Exception e) |
| | | { |
| | | Db.RollbackTran(); |
| | | throw new Exception(e.Message); |
| | | } |
| | | } |
| | | |
| | | /// <summary> |
| | | /// 车间绑定托盘 不贴标物料 |
| | | /// </summary> |
| | | /// <param name="model"></param> |
| | | /// <param name="userId"></param> |
| | | /// <exception cref="Exception"></exception> |
| | | public void ChejianQtyIn(string palletNo, string skuNo, string lotNo, decimal qty, string areaNo, int userId) |
| | | { |
| | | try |
| | | { |
| | | #region MyRegion |
| | | |
| | | if (string.IsNullOrWhiteSpace(palletNo)) |
| | | { |
| | | throw new Exception("托盘号不能为空"); |
| | | } |
| | | if (string.IsNullOrWhiteSpace(skuNo)) |
| | | { |
| | | throw new Exception("物料不能为空"); |
| | | } |
| | | if (qty <= 0) |
| | | { |
| | | throw new Exception("数量不能小等0"); |
| | | } |
| | | var skuInfo = Db.Queryable<SysMaterials>().First(m => m.IsDel == "0" && m.SkuNo == skuNo); |
| | | if (skuInfo == null) |
| | | { |
| | | throw new Exception("未查询到物料信息"); |
| | | } |
| | | var pall = Db.Queryable<SysPallets>().First(m => m.IsDel == "0" && m.PalletNo == palletNo); |
| | | if (pall == null) |
| | | { |
| | | throw new Exception("未查询到当前托盘信息"); |
| | | } |
| | | #endregion |
| | | |
| | | //开启事务 |
| | | Db.BeginTran(); |
| | | //当前时间 |
| | | var comTime = DateTime.Now; |
| | | |
| | | #region 包装 |
| | | |
| | | var pack = Db.Queryable<SysPackag>().First(m => m.IsDel == "0" && m.PackagNo == skuInfo.PackagNo); |
| | | |
| | | var pNum = 0;//托盘物品数量 |
| | | var bNum = 0;//箱码物品数量 |
| | | |
| | | //公共方法获取包装数量 |
| | | new Common().GetPackQtyInfo(pack.PackagNo, ref pNum, ref bNum); |
| | | |
| | | #endregion |
| | | |
| | | |
| | | |
| | | #region 库存明细 |
| | | |
| | | var area = Db.Queryable<SysStorageArea>().First(m => m.IsDel == "0" && m.AreaNo == areaNo); |
| | | if (area == null) |
| | | { |
| | | throw new Exception("入库区域不能为空"); |
| | | } |
| | | |
| | | var tags = "0"; |
| | | |
| | | // 判断库存明细是否已有此托盘信息 |
| | | var sd1 = Db.Queryable<DataStockDetail>().First(m => m.IsDel == "0" && m.SkuNo == skuNo && m.LotNo == lotNo && m.PalletNo == palletNo); |
| | | var sdId1 = 0; |
| | | if (sd1 != null) |
| | | { |
| | | if (sd1.AreaNo != areaNo) |
| | | { |
| | | throw new Exception("选择的区域与库存不同"); |
| | | } |
| | | sdId1 = sd1.Id; |
| | | // 库存已存在 更新数据 |
| | | sd1.Qty += qty; |
| | | sd1.CompleteTime = comTime; |
| | | sd1.UpdateUser = userId; |
| | | sd1.UpdateTime = comTime; |
| | | if (sd1.Qty >= pNum) |
| | | { |
| | | sd1.BitPalletMark = "0"; |
| | | } |
| | | Db.Updateable(sd1).ExecuteCommand(); |
| | | } |
| | | else |
| | | { |
| | | // 库存不存在 插入数据 |
| | | sd1 = new DataStockDetail() |
| | | { |
| | | LotNo = lotNo, |
| | | SupplierLot = "", |
| | | SkuNo = skuInfo.SkuNo, |
| | | SkuName = skuInfo.SkuName, |
| | | Standard = skuInfo.Standard, |
| | | Qty = qty, |
| | | LockQty = 0, |
| | | FrozenQty = 0, |
| | | InspectQty = 0, |
| | | WareHouseNo = area.WareHouseNo,//所属仓库 |
| | | RoadwayNo = "",//所属巷道 |
| | | AreaNo = area.AreaNo,//所属区域 |
| | | LocatNo = "",//储位地址 |
| | | PalletNo = palletNo, |
| | | PalletTags = tags, |
| | | CompleteTime = comTime, |
| | | //ProductionTime = boxInfoOne.ProductionTime, |
| | | //ExpirationTime = boxInfoOne.ExpirationTime, |
| | | Status = "0", |
| | | InspectMark = "0", |
| | | InspectStatus = "1", |
| | | BitPalletMark = qty >= pNum ?"0" :"1", |
| | | PackagNo = skuInfo.PackagNo, |
| | | |
| | | IsDel = "0", |
| | | CreateUser = 0, |
| | | CreateTime = comTime |
| | | }; |
| | | |
| | | //添加库存明细 |
| | | sdId1 = Db.Insertable(sd1).ExecuteReturnIdentity(); |
| | | } |
| | | #endregion |
| | | |
| | | // 更改箱支关系表 |
| | | decimal factQty = 0.00m;//托盘总数量 |
| | | |
| | | |
| | | #region 库存 |
| | | var dataStock = Db.Queryable<DataStock>().First(m => m.IsDel == "0" && m.SkuNo == skuInfo.SkuNo && m.LotNo == lotNo); |
| | | if (dataStock != null) |
| | | { |
| | | dataStock.Qty += factQty; |
| | | Db.Updateable(dataStock).ExecuteCommand(); |
| | | } |
| | | else |
| | | { |
| | | var stock = new DataStock() |
| | | { |
| | | SkuNo = skuInfo.SkuNo, |
| | | SkuName = skuInfo.SkuName, |
| | | Standard = skuInfo.Standard, |
| | | LotNo = lotNo, |
| | | LotText = "", |
| | | Qty = qty, |
| | | LockQty = 0, |
| | | FrozenQty = 0, |
| | | IsSampling = "0", |
| | | IsDel = "0", |
| | | CreateUser = userId, |
| | | CreateTime = comTime |
| | | }; |
| | | Db.Insertable(stock).ExecuteCommand(); |
| | | } |
| | | #endregion |
| | | |
| | | // 更改托盘使用状态 |
| | | var sqlStr = $"update SysPallets set Status = '1' where PalletNo = '{palletNo}';"; |
| | | ////添加托盘记录表数据 |
| | | //sqlStr += $"insert into LogPalletTrack values('{palletNo}','{boxNo}','组盘','0',getDate(),{userId},NULL,NULL);"; |
| | | Db.Ado.ExecuteCommand(sqlStr); |
| | | new OperationASNServer().AddLogOperationAsn("PDA模块", "车间入库", skuNo, "添加", $"添加了托盘码为:{palletNo}的入库信息", userId); |
| | | |
| | | //提交事务 |
| | | Db.CommitTran(); |
| | | |
| | | } |
| | | catch (Exception e) |
| | | { |
| | | Db.RollbackTran(); |
| | | throw new Exception(e.Message); |
| | | } |
| | | |
| | | } |
| | | |
| | | #endregion |
| | | // 获取单据列表 |
| | | public List<ArrivalNoticeDto> GetArrivalNotices(ArrivalNoticeVm model) |