| | |
| | | } |
| | | |
| | | //获取要盘点的箱码信息(盘点记录中数据) |
| | | 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); |
| | | } |
| | | List<StockCheckLogDto> data = new List<StockCheckLogDto>(); |
| | | //判断是否为无码物料 |
| | | if (isQtySku == 1) |
| | | { |
| | | //获取库存信息 |
| | | var stockDetail = Db.Queryable<DataStockDetail>().First(a => a.IsDel == "0" && a.Status == "3" && a.SkuNo == sku && a.PalletNo == palletNo); |
| | | |
| | | var data = list.Select(m => new StockCheckLogDto() |
| | | 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, |
| | |
| | | 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("未查询到未盘点的箱支信息"); |
| | | } |
| | |
| | | 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; |
| | | Db.Updateable(checkDetail).ExecuteCommand(); |
| | | Db.Updateable(list).ExecuteCommand(); |
| | | } |
| | | //盘盈 |
| | | else if (result == "2") |
| | | { |
| | | if (isContinue == "0") |
| | | { |
| | | if (string.IsNullOrWhiteSpace(boxNo) || string.IsNullOrWhiteSpace(boxNo3)) |
| | | { |
| | | throw new Exception("盘盈时箱码与支码不能为空"); |
| | | } |
| | | |
| | | } |
| | | if (qty == null || qty <= 0) |
| | | { |
| | | throw new Exception("盘盈时数量不能为空且需大于0"); |
| | | } |
| | | |
| | | if (isContinue == "0") |
| | | { |
| | | var count = Db.Queryable<DataBoxInfo>() |
| | | .Count(m => m.IsDel == "0" && m.BoxNo == boxNo && m.BoxNo3 == boxNo3); |
| | | var count2 = Db.Queryable<BllStockCheckLog>() |
| | |
| | | { |
| | | throw new Exception("当前库存中已存在该箱支信息"); |
| | | } |
| | | var crLog = new BllStockCheckLog() |
| | | } |
| | | BllStockCheckLog crLog = new BllStockCheckLog(); |
| | | if (isContinue == "0") |
| | | { |
| | | crLog = new BllStockCheckLog() |
| | | { |
| | | CRNo = crNo, |
| | | PalletNo = palletNo, |
| | |
| | | CreateUser = userId, |
| | | CreateTime = time |
| | | }; |
| | | if (checkDetail.RealQty == null) |
| | | } |
| | | 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(); |
| | | 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); |