/// <summary> /// 保存流利货架箱子拣货信息 /// </summary> /// <param name="pickOutPlanID">拣货计划ID</param> /// <param name="strStockUpBillNo">备货单编号</param> /// <param name="palletIndex">备货单内托盘序号</param> /// <param name="strNewPalletNo">新托盘号</param> /// <param name="strOldBoxNo">原箱号</param> /// <param name="strNewBoxNo">新箱号</param> /// <param name="pickOutNum">拣货数量</param> /// <param name="strOperType">操作类型:01 流利货架拣货,02 拆托合托</param> /// <returns></returns> public bool SavePickOutInfo_DE(int pickOutPlanID, string strStockUpBillNo, int palletIndex, string strNewPalletNo, string strOldBoxNo, string strNewBoxNo, int pickOutNum, string strOperType) { bool ret = false; SqlTransaction trans = null; SCommBB commBB = new SCommBB(this.connection); BArrangeBillBoxBB arrangeBillBoxBB = new BArrangeBillBoxBB(this.connection); CDEPickOutBoxBB DEPickOutBoxBB = new CDEPickOutBoxBB(this.connection); LMaterialBB materialBB = new LMaterialBB(); LWareBB wareBB = new LWareBB(); UStockOutInDetailBB stockOutInDetailBB = new UStockOutInDetailBB(this.connection); CPickOutPlanBB pickOutPlanBB = new CPickOutPlanBB(); try { if (this.transaction == null) { trans = this.connection.BeginTransaction("TranSave"); this.stockBB.Transaction = trans; commBB.Transaction = trans; arrangeBillBoxBB.Transaction = trans; DEPickOutBoxBB.Transaction = trans; stockOutInDetailBB.Transaction = trans; } else { this.stockBB.Transaction = this.transaction; commBB.Transaction = this.transaction; arrangeBillBoxBB.Transaction = this.transaction; DEPickOutBoxBB.Transaction = this.transaction; stockOutInDetailBB.Transaction = this.transaction; } DataTable dtArrangeBillBox = new DataTable(); DataTable dtPallet = new DataTable(); DataTable dtMaterial = new DataTable(); DataTable dtStock = new DataTable(); CDEPickOutBoxData DEPickOutBoxModel = new CDEPickOutBoxData(); UStockOutInDetailData stockOutInDetailModel = new UStockOutInDetailData(); UStockData stockModel = new UStockData(); CPickOutPlanData pickOutPlanModel = new CPickOutPlanData(); string strSql = "", strPreWareLocatorNo = ""; int stockNum = 0; object obj = null; //获取箱信息 dtArrangeBillBox = arrangeBillBoxBB.GetVList("boxNo='" + strOldBoxNo + "'").Tables[0]; if (dtArrangeBillBox.Rows.Count == 0) { return false; } //获取当前托盘上的库存明细 obj = commBB.ExecuteScalar("select count(1) from dbo.UStock where palletNo='" + strNewPalletNo + "' and num>0"); if (obj != null) { stockNum = Convert.ToInt32(obj); } //扫描箱所在库位 strPreWareLocatorNo = dtArrangeBillBox.Rows[0]["wareLocatorNo"].ToString(); //获取托盘上的正式物料箱 dtPallet = arrangeBillBoxBB.GetVList("palletNo='" + strNewPalletNo + "' and isnull(wareNo,'')<>''").Tables[0]; //获取箱内物料信息 dtMaterial = materialBB.GetList("materialNo='" + dtArrangeBillBox.Rows[0]["materialNo"].ToString() + "'").Tables[0]; //获取拣货计划实例 pickOutPlanModel = pickOutPlanBB.GetModel(pickOutPlanID); //增加出入库明细-原箱出库 dtStock = stockBB.GetList("boxNo='" + strOldBoxNo + "'").Tables[0]; if (dtStock.Rows.Count > 0)//原箱有库存 { //保存出入库明细数据-出库 stockOutInDetailModel = new UStockOutInDetailData(); stockOutInDetailModel.billNo = strStockUpBillNo;//单据编号 stockOutInDetailModel.outInType = "08";//拆托合托 stockOutInDetailModel.isOut = true;//是否出库 stockOutInDetailModel.stockDt = System.DateTime.Today.ToString();//库存日期 stockOutInDetailModel.dt = System.DateTime.Today.ToString();//操作日期 stockOutInDetailModel.wareNo = dtArrangeBillBox.Rows[0]["wareNo"].ToString();//仓库 stockOutInDetailModel.wareLocatorNo = dtArrangeBillBox.Rows[0]["wareLocatorNo"].ToString();//库位 stockOutInDetailModel.salverNo = dtArrangeBillBox.Rows[0]["palletNo"].ToString();//托盘号 stockOutInDetailModel.boxNo = strOldBoxNo;//箱号 stockOutInDetailModel.materialNo = dtArrangeBillBox.Rows[0]["materialNo"].ToString();//物料编号 stockOutInDetailModel.factMonomerNum = Convert.ToDouble(dtMaterial.Rows[0]["U_UintQty"]);//单体数量 stockOutInDetailModel.factPackNum = Convert.ToDouble(dtMaterial.Rows[0]["U_BoxQty"]);//整箱数量 stockOutInDetailModel.num = pickOutNum;//数量 stockOutInDetailModel.nextBoxNo = strNewBoxNo;//拆箱目的箱号 stockOutInDetailModel.isrtEmpId = this.empId; stockOutInDetailModel.isrtDt = System.DateTime.Now.ToString(); stockOutInDetailBB.AddRecord(stockOutInDetailModel); } //更改正式库存信息 commBB.ExecuteSql("update dbo.UStock set num=num-" + pickOutNum.ToString() + " where boxNo='" + strOldBoxNo + "'"); #region 拣货信息赋值 DEPickOutBoxModel = new CDEPickOutBoxData(); DEPickOutBoxModel.boxNo = strNewBoxNo;//新箱号 DEPickOutBoxModel.oldBoxNo = strOldBoxNo;//原箱号 DEPickOutBoxModel.materialNo = dtArrangeBillBox.Rows[0]["materialNo"].ToString();//物料编号 DEPickOutBoxModel.num = pickOutNum;//拣货数量 DEPickOutBoxModel.palletNo = strNewPalletNo;//新托盘号 DEPickOutBoxModel.region = "";//新区域 DEPickOutBoxModel.oldPalletNo = dtArrangeBillBox.Rows[0]["palletNo"].ToString();//原托盘号 DEPickOutBoxModel.oldRegion = dtArrangeBillBox.Rows[0]["region"].ToString();//原区域 DEPickOutBoxModel.preWareNo = dtArrangeBillBox.Rows[0]["wareNo"].ToString();//原库区 DEPickOutBoxModel.preWareLocatorNo = dtArrangeBillBox.Rows[0]["wareLocatorNo"].ToString(); //原库位 DEPickOutBoxModel.stockUpBillNo = strStockUpBillNo;//备货单编号 DEPickOutBoxModel.palletIndex = palletIndex;//托盘序号 if (pickOutPlanModel != null) { DEPickOutBoxModel.absEntry = pickOutPlanModel.absEntry; DEPickOutBoxModel.saleBillNo = pickOutPlanModel.saleBillNo; DEPickOutBoxModel.lineNum = pickOutPlanModel.lineNum; DEPickOutBoxModel.DocEntry = pickOutPlanModel.DocEntry; } DEPickOutBoxModel.isrtEmpId = this.EmpID;//添加人 DEPickOutBoxModel.isrtDt = System.DateTime.Now.ToString();//添加时间 #endregion 拣货信息赋值 //添加库存明细--高位货架上的托盘 if ((dtPallet.Rows.Count > 0 && dtPallet.Rows[0]["wareType"].ToString() == "03" && strOperType == "02" && dtPallet.Rows[0]["wareLocatorNo"].ToString() != "" && dtPallet.Rows[0]["wareSortNo"].ToString() != "D" && dtPallet.Rows[0]["wareSortNo"].ToString() != "E") || (stockNum > 0 && DEPickOutBoxModel.oldPalletNo != "")) { #region 放置托盘在正式库区 #region 保存拣货信息 DEPickOutBoxModel.wareNo = dtPallet.Rows[0]["wareNo"].ToString();//新库区 DEPickOutBoxModel.wareLocatorNo = dtPallet.Rows[0]["wareLocatorNo"].ToString();//新库位 DEPickOutBoxModel.isOutStock = true;//是否出库 DEPickOutBoxModel.updtDt = System.DateTime.Now.ToString();//更改时间 DEPickOutBoxModel.updtEmpId = this.EmpID;//更改人员 #endregion 保存拣货信息 #region 保存库存明细数据 dtStock = stockBB.GetList("boxNo='" + strNewBoxNo + "' and num>0").Tables[0]; if (dtStock.Rows.Count == 0)//没有库存 { //增加库存明细 stockModel = new UStockData(); stockModel.wareNo = dtPallet.Rows[0]["wareNo"].ToString();//仓库 stockModel.wareLocatorNo = dtPallet.Rows[0]["wareLocatorNo"].ToString();//库位 stockModel.stockDt = System.DateTime.Today.ToString();//库存日期 stockModel.palletNo = strNewPalletNo;//托盘号 stockModel.materialNo = dtArrangeBillBox.Rows[0]["materialNo"].ToString();//物料编号 stockModel.boxNo = strNewBoxNo;//箱号 stockModel.factMonomerNum = Convert.ToDouble(dtMaterial.Rows[0]["U_UintQty"]);//单体数量 stockModel.factPackNum = Convert.ToDouble(dtMaterial.Rows[0]["U_BoxQty"]);//整箱数量 stockModel.num = pickOutNum;//数量 stockModel.isOutStocking = false;//是否正在出库 stockModel.stockMark = "拆托合托"; stockBB.AddRecord(stockModel); } else//已有库存 { strSql = "update dbo.UStock set num=num+" + pickOutNum.ToString() + " where boxNo='" + strNewBoxNo + "'"; commBB.ExecuteSql(strSql); } //增加出入库明细-新箱入库 stockOutInDetailModel = new UStockOutInDetailData(); stockOutInDetailModel.billNo = strStockUpBillNo;//单据编号 stockOutInDetailModel.outInType = "08";//拆托合托 stockOutInDetailModel.isOut = false;//是否出库 stockOutInDetailModel.stockDt = System.DateTime.Today.ToString();//库存日期 stockOutInDetailModel.dt = System.DateTime.Today.ToString();//操作日期 stockOutInDetailModel.wareNo = dtPallet.Rows[0]["wareNo"].ToString();//仓库 stockOutInDetailModel.wareLocatorNo = dtPallet.Rows[0]["wareLocatorNo"].ToString();//库位 stockOutInDetailModel.salverNo = strNewPalletNo;//托盘号 stockOutInDetailModel.boxNo = strNewBoxNo;//箱号 stockOutInDetailModel.materialNo = dtArrangeBillBox.Rows[0]["materialNo"].ToString();//物料编号 stockOutInDetailModel.factMonomerNum = Convert.ToDouble(dtMaterial.Rows[0]["U_UintQty"]);//单体数量 stockOutInDetailModel.factPackNum = Convert.ToDouble(dtMaterial.Rows[0]["U_BoxQty"]);//整箱数量 stockOutInDetailModel.num = pickOutNum;//数量 stockOutInDetailModel.nextBoxNo = "";//拆箱目的箱号 stockOutInDetailModel.isrtEmpId = this.empId; stockOutInDetailModel.isrtDt = System.DateTime.Now.ToString(); stockOutInDetailBB.AddRecord(stockOutInDetailModel); #endregion 保存库存明细数据 //更改排托箱入库信息 commBB.ExecuteSql("update dbo.BArrangeBillBox set inStockDt=getDate(),inStockEmpId=" + this.EmpID.ToString() + ",inStockNum='" + stockOutInDetailModel.num.ToString() + "',isOutStocking=0 where boxNo='" + stockOutInDetailModel.boxNo + "' and isnull(wareNo,'')<>'' and inStockDt is null"); #endregion 放置托盘在正式库区 } else { #region 保存流利货架拣货或非正式库拆托组托信息或拆到空托盘 if (DEPickOutBoxModel.oldPalletNo != "")//非正式库拆托组托或拆到空托盘 { if (dtPallet.Rows.Count > 0 && dtPallet.Rows[0]["wareNo"].ToString().IndexOf("GLHJ") == -1 && dtPallet.Rows[0]["wareLocatorNo"].ToString() != "")//新托盘上已有物料箱,将物料放到原有托盘 { DEPickOutBoxModel.wareNo = dtPallet.Rows[0]["wareNo"].ToString();//新库区 DEPickOutBoxModel.wareLocatorNo = dtPallet.Rows[0]["wareLocatorNo"].ToString();//新库位 } else { DEPickOutBoxModel.wareNo = dtArrangeBillBox.Rows[0]["wareNo"].ToString();//新库区 DEPickOutBoxModel.wareLocatorNo = "";//放到空托盘 } //是否出库 if (DEPickOutBoxModel.wareLocatorNo != "")//非正式库拆托组托 { DEPickOutBoxModel.isOutStock = true;//是否出库 DEPickOutBoxModel.updtDt = System.DateTime.Now.ToString();//更改时间 DEPickOutBoxModel.updtEmpId = this.EmpID;//更改人员 } else { //拆到空托盘 DEPickOutBoxModel.isOutStock = false; } } else//流利货架拣货 { DEPickOutBoxModel.wareNo = dtArrangeBillBox.Rows[0]["wareNo"].ToString();//新库区 DEPickOutBoxModel.wareLocatorNo = dtArrangeBillBox.Rows[0]["wareLocatorNo"].ToString();//新库位 DEPickOutBoxModel.isOutStock = false;//是否出库 } #endregion 保存流利货架拣货或非正式库拆托组托信息或拆到空托盘 } //保存拣货信息 DEPickOutBoxBB.AddRecord(DEPickOutBoxModel); //拣货处理逻辑更改为:根据实际需要数量进行拣货 //处理情况分为:整箱拣货、拆箱拣货 if (strNewBoxNo == strOldBoxNo)//整箱拣货 { if (DEPickOutBoxModel.oldPalletNo != "" || dtArrangeBillBox.Rows[0]["wareNo"] == DBNull.Value || dtArrangeBillBox.Rows[0]["wareNo"].ToString() == "")//非流利货架或已出库箱重新入库 { //物料箱库位赋值 commBB.ExecuteSql("update dbo.BArrangeBillBox set oldPalletNo=palletNo,palletNo='" + strNewPalletNo + "',region=oldRegion,oldRegion='',preWareNo=wareNo,preWareLocatorNo=wareLocatorNo,wareNo='" + DEPickOutBoxModel.wareNo + "',wareLocatorNo='" + DEPickOutBoxModel.wareLocatorNo + "',stockUpBillNo='" + strStockUpBillNo + "' where boxNo='" + strOldBoxNo + "'"); } else { //流利货架,库位赋空值 commBB.ExecuteSql("update dbo.BArrangeBillBox set oldPalletNo=palletNo,palletNo='" + strNewPalletNo + "',region=oldRegion,oldRegion='',preWareNo=wareNo,preWareLocatorNo=wareLocatorNo,wareNo='" + DEPickOutBoxModel.wareNo + "',wareLocatorNo='',stockUpBillNo='" + strStockUpBillNo + "' where boxNo='" + strOldBoxNo + "'"); } } //如果原箱剩余数量为0,清空原箱的托盘号、库区、库位 dtArrangeBillBox = arrangeBillBoxBB.GetVList("boxNo='" + strOldBoxNo + "'").Tables[0]; if (Convert.ToInt32(dtArrangeBillBox.Rows[0]["leavingNum"]) == 0) { commBB.ExecuteSql(@"update dbo.BArrangeBillBox set oldPalletNo=palletNo,palletNo='',preWareNo=wareNo,preWareLocatorNo=wareLocatorNo, wareNo='',wareLocatorNo='',stockUpBillNo='" + strStockUpBillNo + "' where boxNo='" + strOldBoxNo + "'"); } #region 新增新的排托箱 DataTable dtArrangeBillBoxNew = new DataTable(); dtArrangeBillBoxNew = arrangeBillBoxBB.GetList("boxNo='" + strNewBoxNo + "'").Tables[0]; //新增新的排托箱 if (dtArrangeBillBoxNew.Rows.Count == 0) { BArrangeBillBoxData newArrangeBillBoxModel = new BArrangeBillBoxData(); newArrangeBillBoxModel.arriveBillNo = "";//到货单号 newArrangeBillBoxModel.financeBillNo = dtArrangeBillBox.Rows[0]["financeBillNo"].ToString();//采购订单号 newArrangeBillBoxModel.arrangeBillNo = "";//排托单号 newArrangeBillBoxModel.stockUpBillNo = strStockUpBillNo;//备货单编号 newArrangeBillBoxModel.boxNo = strNewBoxNo;//箱号 newArrangeBillBoxModel.oldBoxNo = strOldBoxNo;//原箱号 newArrangeBillBoxModel.materialNo = dtArrangeBillBox.Rows[0]["materialNo"].ToString();//物料编号 newArrangeBillBoxModel.factNum = 0;//数量,赋0值通过拣货清单计算实际数量 newArrangeBillBoxModel.palletNo = strNewPalletNo;//托盘号 newArrangeBillBoxModel.region = "";//区域 newArrangeBillBoxModel.oldPalletNo = dtArrangeBillBox.Rows[0]["palletNo"].ToString();//原托盘号 newArrangeBillBoxModel.oldRegion = dtArrangeBillBox.Rows[0]["region"].ToString();//原托内区域 newArrangeBillBoxModel.wareNo = dtArrangeBillBox.Rows[0]["wareNo"].ToString();//库区 if (DEPickOutBoxModel.oldPalletNo != "")//非流利货架 { newArrangeBillBoxModel.wareLocatorNo = DEPickOutBoxModel.wareLocatorNo;//库位 } else//流利货架 { newArrangeBillBoxModel.wareLocatorNo = "";//库位 } newArrangeBillBoxModel.preWareNo = dtArrangeBillBox.Rows[0]["wareNo"].ToString();//原库区 newArrangeBillBoxModel.preWareLocatorNo = dtArrangeBillBox.Rows[0]["wareLocatorNo"].ToString();//原库位 newArrangeBillBoxModel.isBoxArrange = true;//是否排托 newArrangeBillBoxModel.isPalletUsing = true;//托盘是否正在使用 newArrangeBillBoxModel.acceptEmpId = this.EmpID;//接收人 newArrangeBillBoxModel.acceptDt = System.DateTime.Now.ToString();//接收时间 newArrangeBillBoxModel.checkResult = Convert.ToBoolean(dtArrangeBillBox.Rows[0]["checkResult"]);//校验结果 newArrangeBillBoxModel.isOutStocking = false;//是否正在出库 newArrangeBillBoxModel.noPassReasonId = Convert.ToInt32(dtArrangeBillBox.Rows[0]["noPassReasonId"]);//不合格原因 newArrangeBillBoxModel.noPassMark = dtArrangeBillBox.Rows[0]["noPassMark"].ToString();//不合格备注 arrangeBillBoxBB.AddRecord(newArrangeBillBoxModel); } #endregion 新增新的排托箱 //库存明细数量为0,删除信息 strSql = "delete from dbo.UStock where num=0"; commBB.ExecuteSql(strSql); //更改库存中原箱的是否锁定状态 strSql = "update dbo.UStock set isOutStocking=0 where id in (select top 1 id from dbo.UStock where wareLocatorNo='" + strPreWareLocatorNo + "' and materialNo='" + dtArrangeBillBox.Rows[0]["materialNo"].ToString() + "' and isOutStocking=1 order by id)"; commBB.ExecuteSql(strSql); //更改原箱的是否锁定状态 strSql = "update dbo.BArrangeBillBox set isOutStocking=0 where id in (select top 1 id from dbo.BArrangeBillBox where wareLocatorNo='" + strPreWareLocatorNo + "' and materialNo='" + dtArrangeBillBox.Rows[0]["materialNo"].ToString() + "' and isOutStocking=1 order by id)"; commBB.ExecuteSql(strSql); //释放库位,首先判断原托盘上是否有物料 strSql = @"update dbo.LWareLocator set isUsing=0 where not exists(select 1 from dbo.BArrangeBillBox as t where t.wareLocatorNo=dbo.LWareLocator.wareLocatorNo) and isUsing=1 and isDel=0 and wareLocatorNo='" + strPreWareLocatorNo + "'"; commBB.ExecuteSql(strSql); if (this.transaction == null) trans.Commit(); ret = true; } catch { if (transaction == null) trans.Rollback("TranSave"); throw new Exception("保存信息失败!"); } finally { commBB.Dispose(); arrangeBillBoxBB.Dispose(); DEPickOutBoxBB.Dispose(); materialBB.Dispose(); wareBB.Dispose(); stockOutInDetailBB.Dispose(); pickOutPlanBB.Dispose(); } return ret; }
/// <summary> /// 删除提货单 /// </summary> /// <param name="absEntry">提货单ID</param> /// <returns></returns> public bool DeleteSaleBill(int absEntry) { bool ret = false; SCommBB commBB = new SCommBB(this.connection); CStockUpBillBB stockUpBillBB = new CStockUpBillBB(this.connection); CPickOutPlanBB pickOutPlanBB = new CPickOutPlanBB(this.connection); SqlTransaction trans = null; try { if (this.transaction == null) { trans = this.connection.BeginTransaction("TransDelete"); commBB.Transaction = trans; stockUpBillBB.Transaction = trans; pickOutPlanBB.Transaction = trans; } else { commBB.Transaction = this.transaction; stockUpBillBB.Transaction = this.transaction; pickOutPlanBB.Transaction = this.transaction; } string strStockUpBillNo = ""; DataTable dtStockUpBill = new DataTable(); DataTable dtPickOutPlan = new DataTable(); //删除销售订单 commBB.ExecuteSql("delete from dbo.CSaleBill where absEntry=" + absEntry.ToString()); //删除销售订单明细 commBB.ExecuteSql("delete from dbo.CSaleDetail where absEntry=" + absEntry.ToString()); //删除销售订单临时表 //commBB.ExecuteSql("delete from dbo.CSaleBill_HangHao where absEntry=" + absEntry.ToString()); //删除销售订单明细临时表 //commBB.ExecuteSql("delete from dbo.CSaleDetail_HangHao where absEntry=" + absEntry.ToString()); //获取备货单编号 //dtStockUpBill = stockUpBillBB.GetList("absEntrys='" + absEntry.ToString() + "'").Tables[0]; //if (dtStockUpBill.Rows.Count > 0) //{ // strStockUpBillNo = dtStockUpBill.Rows[0]["stockUpBillNo"].ToString();//备货单编号 // dtPickOutPlan = pickOutPlanBB.GetList("stockUpBillNo='" + strStockUpBillNo + "'").Tables[0]; // foreach (DataRow row in dtPickOutPlan.Rows) // { // commBB.ExecuteSql("update dbo.UStock set isOutStocking=0 where wareLocatorNo='" + row["wareLocatorNo"].ToString() + "'"); // } // //删除备货单 // commBB.ExecuteSql("delete from dbo.CStockUpBill where stockUpBillNo='" + strStockUpBillNo + "'"); // //删除备货单明细 // commBB.ExecuteSql("delete from dbo.CStockUpDetail where stockUpBillNo='" + strStockUpBillNo + "'"); // //删除拣货计划 // commBB.ExecuteSql("delete from dbo.CPickOutPlan where stockUpBillNo='" + strStockUpBillNo + "'"); //} if (this.transaction == null) trans.Commit(); ret = true; } catch (Exception ex) { if (this.transaction == null) trans.Rollback("TransDelete"); throw ex; } finally { commBB.Dispose(); stockUpBillBB.Dispose(); pickOutPlanBB.Dispose(); } return ret; }
/// <summary> /// 执行叉车任务 /// </summary> /// <returns></returns> public bool ExecuteEffectForkliftTask(int taskId) { bool ret = false; SqlTransaction trans = null; SCommBB commBB = new SCommBB(this.connection); BTallyBillBB tallyBillBB = new BTallyBillBB(this.connection); UStockBB stockBB = new UStockBB(this.connection); UStockOutInDetailBB stockOutInDetailBB = new UStockOutInDetailBB(this.connection); BArrangeBillBoxBB arrangeBillBoxBB = new BArrangeBillBoxBB(this.connection); BTallyBillDetailBB tallyBillDetailBB = new BTallyBillDetailBB(); LMaterialBB materialBB = new LMaterialBB(); LWareLocatorBB wareLocatorBB = new LWareLocatorBB(); LWareBB wareBB = new LWareBB(); CPickOutPlanBB pickOutPlanBB = new CPickOutPlanBB(); CDEPickOutBoxBB DEPickOutBoxBB = new CDEPickOutBoxBB(this.connection); try { if (this.transaction == null) { trans = this.connection.BeginTransaction("TransSave"); this.forkliftTaskBB.Transaction = trans; commBB.Transaction = trans; tallyBillBB.Transaction = trans; stockBB.Transaction = trans; stockOutInDetailBB.Transaction = trans; arrangeBillBoxBB.Transaction = trans; DEPickOutBoxBB.Transaction = trans; } else { this.forkliftTaskBB.Transaction = this.transaction; commBB.Transaction = this.transaction; tallyBillBB.Transaction = this.transaction; stockBB.Transaction = this.transaction; stockOutInDetailBB.Transaction = this.transaction; arrangeBillBoxBB.Transaction = this.transaction; DEPickOutBoxBB.Transaction = this.transaction; } BForkliftTaskData forkliftTaskModel = new BForkliftTaskData(); UStockData stockModel = new UStockData(); UStockOutInDetailData stockOutInDetailModel = new UStockOutInDetailData(); DataTable dtPreWare = new DataTable(); DataTable dtNextWare = new DataTable(); DataTable dtBox = new DataTable(); DataTable dtMaterial = new DataTable(); DataTable dtPallet = new DataTable(); string strSql = ""; #region 修改叉车任务的处理信息 //修改叉车任务的处理信息 forkliftTaskModel = forkliftTaskBB.GetModel(taskId); forkliftTaskModel.isDeal = true; forkliftTaskModel.dealEmpId = this.empId; forkliftTaskModel.dealDt = System.DateTime.Now.ToString(); //if (forkliftTaskModel.taskType == "01") //{ //} //forkliftTaskBB.ModifyRecord(forkliftTaskModel); #endregion 修改叉车任务的处理信息 //获取源库区信息 dtPreWare = wareBB.GetList("wareNo='" + forkliftTaskModel.preWareNo + "'").Tables[0]; //获取目的库区信息 dtNextWare = wareBB.GetList("wareNo='" + forkliftTaskModel.nextWareNo + "'").Tables[0]; //获取托盘上的所有物料箱 dtPallet = arrangeBillBoxBB.GetList("palletNo='" + forkliftTaskModel.palletNo + "' and isnull(wareNo,'')<>''").Tables[0]; //2015-01-30 添加 用于增加备货单号 if (forkliftTaskModel.taskType == "01") { if (dtPallet.Rows.Count > 0) { forkliftTaskModel.stockUpBillNo = dtPallet.Rows[0]["arriveBillNo"].ToString(); } } forkliftTaskBB.ModifyRecord(forkliftTaskModel); if (dtPallet.Rows.Count == 0) { //如果托盘上没有箱,释放库位 commBB.ExecuteSql("update dbo.LWareLocator set isUsing=0 where wareLocatorNo='" + forkliftTaskModel.nextLocatorNo + "'"); } #region 更改箱子库位 //更改流利货架拣货箱库位信息 commBB.ExecuteSql("update dbo.CDEPickOutBox set isOutStock=1,updtDt=getDate(),updtEmpId=" + this.EmpID.ToString() + " where palletNo='" + forkliftTaskModel.palletNo + "' and isOutStock=0"); //更改排托箱库位信息 commBB.ExecuteSql("update dbo.BArrangeBillBox set preWareNo=wareNo,wareNo='" + forkliftTaskModel.nextWareNo + "',preWareLocatorNo=wareLocatorNo,wareLocatorNo='" + forkliftTaskModel.nextLocatorNo + "' where palletNo='" + forkliftTaskModel.palletNo + "' and isnull(wareNo,'')<>''"); #endregion 更改箱子库位 //释放源库位 commBB.ExecuteSql("update dbo.LWareLocator set isUsing=0 where wareLocatorNo='" + forkliftTaskModel.preLocatorNo + "'"); if (forkliftTaskModel.taskType == "03" || forkliftTaskModel.taskType == "11") { #region 从理货区到正式库区、从质检区到正式库区(非标准箱) object obj = null; int tallyBillId = 0; BTallyBillData tallyBillModel = new BTallyBillData(); obj = commBB.ExecuteScalar("select top 1 id from dbo.BTallyBill where palletNo='" + forkliftTaskModel.palletNo + "' and instantState='02' order by id desc"); if (obj != null) { #region 修改排托单信息 tallyBillId = Convert.ToInt32(obj); tallyBillModel = tallyBillBB.GetModel(tallyBillId); tallyBillModel.instantState = "03";//指定状态为“已入库” tallyBillModel.isInStock = true;// 入库状态 tallyBillModel.wareNo = forkliftTaskModel.nextWareNo;//库区 tallyBillModel.wareLocatorNo = forkliftTaskModel.nextLocatorNo;//库位 tallyBillBB.ModifyRecord(tallyBillModel); #endregion 修改排托单信息 } #region 出入库和出入库明细数据操作 if (dtNextWare.Rows[0]["wareSortNo"].ToString() != "D" && dtNextWare.Rows[0]["wareSortNo"].ToString() != "E") { dtBox = arrangeBillBoxBB.GetVList("palletNo='" + forkliftTaskModel.palletNo + "' and isnull(wareNo,'')<>''").Tables[0]; for (int i = 0; i < dtBox.Rows.Count; i++) { dtMaterial = materialBB.GetList("materialNo='" + dtBox.Rows[i]["materialNo"].ToString() + "'").Tables[0]; //保存库存明细数据 stockModel = new UStockData(); stockModel.wareNo = forkliftTaskModel.nextWareNo;//仓库 stockModel.wareLocatorNo = forkliftTaskModel.nextLocatorNo;//库位 stockModel.stockDt = System.DateTime.Today.ToString();//库存日期 stockModel.palletNo = forkliftTaskModel.palletNo;//托盘号 stockModel.materialNo = dtBox.Rows[i]["materialNo"].ToString();//物料编号 stockModel.boxNo = dtBox.Rows[i]["boxNo"].ToString();//箱号 stockModel.factMonomerNum = Convert.ToDouble(dtMaterial.Rows[0]["U_UintQty"]);//单体数量 stockModel.factPackNum = Convert.ToDouble(dtMaterial.Rows[0]["U_BoxQty"]);//整箱数量 stockModel.num = Convert.ToDouble(dtBox.Rows[i]["leavingNum"]) + Convert.ToDouble(dtBox.Rows[i]["DEPickOutNum"]);//数量 stockModel.isOutStocking = false;//是否正在出库 stockModel.stockMark = "从理到正式库2"; stockModel.isrtDt = System.DateTime.Now.ToString();//操作时间 stockModel.isrtEmpId = this.EmpID;//操作人 stockBB.AddRecord(stockModel); //保存出入库明细数据 stockOutInDetailModel = new UStockOutInDetailData(); stockOutInDetailModel.billNo = dtBox.Rows[i]["arriveBillNo"].ToString();//单据编号 stockOutInDetailModel.outInType = "05";//理货入库 stockOutInDetailModel.isOut = false;//是否出库 stockOutInDetailModel.stockDt = System.DateTime.Today.ToString();//库存日期 stockOutInDetailModel.dt = System.DateTime.Today.ToString();//操作日期 stockOutInDetailModel.wareNo = forkliftTaskModel.nextWareNo;//仓库 stockOutInDetailModel.wareLocatorNo = forkliftTaskModel.nextLocatorNo;//库位 stockOutInDetailModel.salverNo = forkliftTaskModel.palletNo;//托盘号 stockOutInDetailModel.boxNo = dtBox.Rows[i]["boxNo"].ToString();//箱号 stockOutInDetailModel.materialNo = dtBox.Rows[i]["materialNo"].ToString();//物料编号 stockOutInDetailModel.factMonomerNum = Convert.ToDouble(dtMaterial.Rows[0]["U_UintQty"]);//单体数量 stockOutInDetailModel.factPackNum = Convert.ToDouble(dtMaterial.Rows[0]["U_BoxQty"]);//整箱数量 stockOutInDetailModel.num = Convert.ToDouble(dtBox.Rows[i]["leavingNum"]) + Convert.ToDouble(dtBox.Rows[i]["DEPickOutNum"]);//数量 stockOutInDetailModel.isrtEmpId = this.empId; stockOutInDetailModel.isrtDt = System.DateTime.Now.ToString(); stockOutInDetailBB.AddRecord(stockOutInDetailModel); //更改排托箱入库信息 commBB.ExecuteSql("update dbo.BArrangeBillBox set inStockDt=getDate(),inStockEmpId=" + this.EmpID.ToString() + ",inStockNum='" + stockOutInDetailModel.num.ToString() + "' where boxNo='" + stockOutInDetailModel.boxNo + "' and isnull(wareNo,'')<>'' and inStockDt is null"); } } //更改排托箱检测结果 commBB.ExecuteSql("update dbo.BArrangeBillBox set checkResult=1,checkResultDt=getDate(),checkResultEmpId=" + this.EmpID.ToString() + " where palletNo='" + forkliftTaskModel.palletNo + "' and isnull(wareNo,'')<>'' and checkResult=0 and checkResultDt is null"); #endregion 出入库和出入库明细数据操作 #endregion 从理货区到正式库区、从质检区到正式库区 } else if (forkliftTaskModel.taskType == "05") { #region 05 从正式库区到拣货区 //更改排托箱库位信息-库位赋值原库位 //commBB.ExecuteSql("update dbo.BArrangeBillBox set wareNo=preWareNo,wareLocatorNo=preWareLocatorNo where palletNo='" // + forkliftTaskModel.palletNo + "' and isnull(wareNo,'')<>''"); //锁定原库位 //commBB.ExecuteSql("update dbo.LWareLocator set isUsing=1 where wareLocatorNo='" // + forkliftTaskModel.preLocatorNo + "'"); #endregion 05 从正式库区到拣货区 } else if (forkliftTaskModel.taskType == "06") { #region 从拣货区到正式库区 //库存处理放在包装线体上 ////获取托盘箱明细 //dtBox = arrangeBillBoxBB.GetVList("palletNo='" + forkliftTaskModel.palletNo // + "' and isnull(wareNo,'')<>''").Tables[0]; //if (dtNextWare.Rows[0]["wareSortNo"].ToString() != "D" // && dtNextWare.Rows[0]["wareSortNo"].ToString() != "E") //{ // for (int i = 0; i < dtBox.Rows.Count; i++) // { // //保存库存明细数据 // stockModel = new UStockData(); // stockModel.wareNo = forkliftTaskModel.nextWareNo;//仓库 // stockModel.wareLocatorNo = forkliftTaskModel.nextLocatorNo;//库位 // stockModel.stockDt = System.DateTime.Today.ToString();//库存日期 // stockModel.palletNo = forkliftTaskModel.palletNo;//托盘号 // stockModel.materialNo = dtBox.Rows[i]["materialNo"].ToString();//物料编号 // stockModel.boxNo = dtBox.Rows[i]["boxNo"].ToString();//箱号 // stockModel.factMonomerNum = Convert.ToDouble(dtMaterial.Rows[0]["U_UintQty"]);//单体数量 // stockModel.factPackNum = Convert.ToDouble(dtMaterial.Rows[0]["U_BoxQty"]);//整箱数量 // stockModel.num = Convert.ToDouble(dtBox.Rows[i]["leavingNum"]) // + Convert.ToDouble(dtBox.Rows[i]["DEPickOutNum"]);//数量 // //stockModel.isOutStocking = Convert.ToBoolean(dtBox.Rows[i]["isOutStocking"]);//是否正在出库 // stockModel.isOutStocking = false;//是否正在出库 // stockModel.stockMark = "从拣货返回正式库"; // stockModel.isrtDt = System.DateTime.Now.ToString();//操作时间 // stockModel.isrtEmpId = this.EmpID;//操作人 // stockBB.AddRecord(stockModel); // //保存出入库明细数据 // stockOutInDetailModel = new UStockOutInDetailData(); // stockOutInDetailModel.billNo = "";//单据编号 // stockOutInDetailModel.outInType = "09";//拣货返回正式库 // stockOutInDetailModel.isOut = false;//是否出库 // stockOutInDetailModel.stockDt = System.DateTime.Today.ToString();//库存日期 // stockOutInDetailModel.dt = System.DateTime.Today.ToString();//操作日期 // stockOutInDetailModel.wareNo = forkliftTaskModel.nextWareNo;//仓库 // stockOutInDetailModel.wareLocatorNo = forkliftTaskModel.nextLocatorNo;//库位 // stockOutInDetailModel.salverNo = forkliftTaskModel.palletNo;//托盘号 // stockOutInDetailModel.boxNo = dtBox.Rows[i]["boxNo"].ToString();//箱号 // stockOutInDetailModel.materialNo = dtBox.Rows[i]["materialNo"].ToString();//物料编号 // stockOutInDetailModel.factMonomerNum = Convert.ToDouble(dtMaterial.Rows[0]["U_UintQty"]);//单体数量 // stockOutInDetailModel.factPackNum = Convert.ToDouble(dtMaterial.Rows[0]["U_BoxQty"]);//整箱数量 // stockOutInDetailModel.num = Convert.ToDouble(dtBox.Rows[i]["leavingNum"]) // + Convert.ToDouble(dtBox.Rows[i]["DEPickOutNum"]);//数量 // stockOutInDetailBB.AddRecord(stockOutInDetailModel); // //更改物料箱是否正在出库状态 // commBB.ExecuteSql("update dbo.BArrangeBillBox set isOutStocking=0 where boxNo='" // + dtBox.Rows[i]["boxNo"].ToString() + "'"); // //更改排托箱入库信息 // commBB.ExecuteSql("update dbo.BArrangeBillBox set inStockDt=getDate(),inStockEmpId=" // + this.EmpID.ToString() + ",inStockNum='" + stockOutInDetailModel.num.ToString() // + "' where boxNo='" + stockOutInDetailModel.boxNo // + "' and isnull(wareNo,'')<>'' and inStockDt is null"); // } //} #endregion 从拣货区到正式库区 } else if (forkliftTaskModel.taskType == "07") { #region 从拣货区出库 //根据托盘号,更改备货单明细的状态(05 出库完成) strSql = "update dbo.CStockUpDetail set instantState='05' where palletNo='" + forkliftTaskModel.palletNo + "'"; commBB.ExecuteSql(strSql); //如果备货单明细的状态全部为“05 出库完成”,更改备货单状态为“10 出库完成” strSql = @"update dbo.CStockUpBill set instantState='10' where not exists(select 1 from dbo.CStockUpDetail as t where t.stockUpBillNo=dbo.CStockUpBill.stockUpBillNo and instantState<>'05')"; commBB.ExecuteSql(strSql); //如果备货单明细的状态不全为“05 出库完成”,更改备货单状态为“09 出库中” strSql = @"update dbo.CStockUpBill set instantState='09' where exists(select 1 from dbo.CStockUpDetail as t where t.stockUpBillNo=dbo.CStockUpBill.stockUpBillNo and instantState<>'05')"; commBB.ExecuteSql(strSql); #endregion 从拣货区出库 } else if (forkliftTaskModel.taskType == "09") { #region 从排托区返回收货区 //更改到货箱库位信息 commBB.ExecuteSql("update dbo.BArrangeBillBox set isPalletUsing=0 where palletNo='" + forkliftTaskModel.palletNo + "' and isnull(wareNo,'')<>''"); #endregion 从排托区返回收货区 } else if (forkliftTaskModel.taskType == "10") { #region 从收货区到质检区(非标准箱) //更改到货箱库位信息 //commBB.ExecuteSql("update dbo.BArrangeBillBox set isPalletUsing=0 where palletNo='" + forkliftTaskModel.palletNo + "' and isnull(wareNo)<>''"); #endregion 从收货区到质检区(非标准箱) } else if (forkliftTaskModel.taskType == "12") { #region 移库处理 #region 源库区、库位处理 //释放源正式库位 commBB.ExecuteSql("update dbo.LWareLocator set isUsing=0 where wareLocatorNo='" + forkliftTaskModel.preLocatorNo + "'"); //如果从正式库出,删除库存明细 if (dtPreWare.Rows[0]["wareType"].ToString() == "03")//正式库区 { //删除库存明细(处理逻辑以后更改成正常的出入库明细) commBB.ExecuteSql("delete from dbo.UStock where palletNo='" + forkliftTaskModel.palletNo + "'"); //增加出入库明细-出库 } #endregion 源库区、库位处理 #region 目的库区、库位处理 //占用目的库位 commBB.ExecuteSql("update dbo.LWareLocator set isUsing=1 where wareLocatorNo='" + forkliftTaskModel.nextLocatorNo + "'"); if (dtNextWare.Rows[0]["wareType"].ToString() == "03")//正式库区 { //DataTable dtDEPickOutBox = new DataTable(); ////获取原托盘所在库位 //dtArrangeBillBox = arrangeBillBoxBB.GetList("palletNo='" + forkliftTaskModel.palletNo + "' and isnull(wareNo,'')<>''").Tables[0]; ////获取流利货架拣货箱信息 //dtDEPickOutBox = DEPickOutBoxBB.GetList("palletNo='" + forkliftTaskModel.palletNo + "' and isOutStock=0").Tables[0]; ////排托箱信息入正式库 //for (int i = 0; i < dtArrangeBillBox.Rows.Count; i++) //{ // dtMaterial = materialBB.GetList("materialNo='" + dtArrangeBillBox.Rows[i]["materialNo"].ToString() + "'").Tables[0]; // //保存库存明细数据 // stockModel = new UStockData(); // stockModel.wareNo = forkliftTaskModel.nextWareNo;//仓库 // stockModel.wareLocatorNo = forkliftTaskModel.nextLocatorNo;//库位 // stockModel.stockDt = System.DateTime.Today.ToString();//库存日期 // stockModel.palletNo = forkliftTaskModel.palletNo;//托盘号 // stockModel.materialNo = dtArrangeBillBox.Rows[i]["materialNo"].ToString();//物料编号 // stockModel.boxNo = dtArrangeBillBox.Rows[i]["boxNo"].ToString();//箱号 // stockModel.factMonomerNum = Convert.ToDouble(dtMaterial.Rows[0]["U_UintQty"]);//单体数量 // stockModel.factPackNum = Convert.ToDouble(dtMaterial.Rows[0]["U_BoxQty"]);//整箱数量 // stockModel.num = Convert.ToDouble(dtArrangeBillBox.Rows[i]["leavingNum"]) + Convert.ToDouble(dtArrangeBillBox.Rows[i]["DEPickOutNum"]);//数量 // stockModel.isOutStocking = false;//是否正在出库 // stockModel.stockMark = "移库(正式箱)"; // stockBB.AddRecord(stockModel); //} ////流利货架拣货箱信息入正式库 //for (int i = 0; i < dtDEPickOutBox.Rows.Count; i++) //{ // dtMaterial = materialBB.GetList("materialNo='" + dtDEPickOutBox.Rows[i]["materialNo"].ToString() + "'").Tables[0]; // //保存库存明细数据 // stockModel = new UStockData(); // stockModel.wareNo = forkliftTaskModel.nextWareNo;//仓库 // stockModel.wareLocatorNo = forkliftTaskModel.nextLocatorNo;//库位 // stockModel.stockDt = System.DateTime.Today.ToString();//库存日期 // stockModel.palletNo = forkliftTaskModel.palletNo;//托盘号 // stockModel.materialNo = dtDEPickOutBox.Rows[i]["materialNo"].ToString();//物料编号 // stockModel.boxNo = dtDEPickOutBox.Rows[i]["boxNo"].ToString();//箱号 // stockModel.factMonomerNum = Convert.ToDouble(dtMaterial.Rows[0]["U_UintQty"]);//单体数量 // stockModel.factPackNum = Convert.ToDouble(dtMaterial.Rows[0]["U_BoxQty"]);//整箱数量 // stockModel.num = Convert.ToDouble(dtDEPickOutBox.Rows[i]["num"]);//数量 // stockModel.isOutStocking = false;//是否正在出库 // stockModel.stockMark = "移库(拣货箱)"; // stockBB.AddRecord(stockModel); //} } #endregion 目的库区、库位处理 #endregion 移库处理 } else if (forkliftTaskModel.taskType == "20") { //托盘出库 DataTable dt = new DataTable(); dt = arrangeBillBoxBB.GetListOnlyStockUpBillNO("palletNo ='" + forkliftTaskModel.palletNo + "' and ISNULL(stockUpBillNo,'')<>''").Tables[0]; commBB.ExecuteSql("update dbo.BArrangeBillBox set oldPalletNo=palletNo,palletNo='',preWareNo=wareNo,wareNo='',preWareLocatorNo=wareLocatorNo,wareLocatorNo=''," + "outStockDt=getDate(),outStockEmpId=" + this.EmpID.ToString() + " where palletNo='" + forkliftTaskModel.palletNo + "' and isnull(wareNo,'')<>''"); commBB.ExecuteSql("update dbo.LWareLocator set isUsing=0 where wareLocatorNo='" + forkliftTaskModel.preLocatorNo + "'"); for (int i = 0; i < dt.Rows.Count; i++) { strSql = @"update dbo.CStockUpDetail set instantState='05' where stockUpBillNo ='" + dt.Rows[i]["stockUpBillNo"].ToString() + "'"; commBB.ExecuteSql(strSql); //如果备货单明细的状态全部为“05 出库完成”,更改备货单状态为“10 出库完成”,并且是关联到一个被货单的形式下 strSql = @"update dbo.CStockUpBill set instantState='10' where stockUpBillNo = '" + dt.Rows[i]["stockUpBillNO"].ToString() + "'"; commBB.ExecuteSql(strSql); } } else if (forkliftTaskModel.taskType == "30")//从质检区到异常区 { //首先作出库处理 //string command = @"Update BArrangeBillBox set oldPalletNo=palletNo,palletNo='',preWareNo=wareNo,wareNo='YCQ',preWareLocatorNo=wareLocatorNo,wareLocatorNo='N01.01'," // + "outStockDt=getDate(),outStockEmpId=" + this.EmpID.ToString() // + " where palletNo='" + forkliftTaskModel.palletNo + "' and isnull(wareNo,'')<>''"; //commBB.ExecuteSql(command); DataSet ds = commBB.Query("select palletNo from BArrangeBillBox where wareLocatorNo = '" + forkliftTaskModel.preLocatorNo + "' group by palletNo"); if (ds.Tables[0].Rows.Count <= 1) { commBB.ExecuteSql("Update dbo.LWareLocator set isUsing=0 where wareLocatorNo='" + forkliftTaskModel.preLocatorNo + "'"); } commBB.ExecuteSql("Update dbo.LWareLocator set isUsing=0 where wareLocatorNo='" + forkliftTaskModel.nextLocatorNo + "'");//N01.01不占用 } if (this.transaction == null) trans.Commit(); ret = true; } catch (Exception ex) { if (this.transaction == null) trans.Rollback("TransSave"); throw ex; } finally { commBB.Dispose(); tallyBillBB.Dispose(); stockBB.Dispose(); stockOutInDetailBB.Dispose(); tallyBillDetailBB.Dispose(); arrangeBillBoxBB.Dispose(); materialBB.Dispose(); wareLocatorBB.Dispose(); wareBB.Dispose(); pickOutPlanBB.Dispose(); DEPickOutBoxBB.Dispose(); } return ret; }