From 6ed23c03a18bf631039bf750ee456a5e2a582bfd Mon Sep 17 00:00:00 2001 From: 王 垚 <1402714037@qq.com> Date: 星期二, 05 一月 2021 14:16:24 +0800 Subject: [PATCH] 代码上传 --- src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs | 943 +++++++++++++++++++++++++++++++++++++++++++++++++--------- 1 files changed, 792 insertions(+), 151 deletions(-) diff --git a/src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs b/src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs index ec48004..c0631ae 100644 --- a/src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs +++ b/src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs @@ -17,6 +17,8 @@ using Kingdee.BOS.ServiceHelper; using Kingdee.BOS.ServiceHelper.FileServer; using Kingdee.BOS.Util; +using Kingdee.K3.Core.SCM.STK; +using Kingdee.K3.SCM.ServiceHelper; using Newtonsoft.Json.Linq; using NPOI.HSSF.UserModel; using NPOI.SS.Formula.Functions; @@ -31,6 +33,7 @@ using System.Runtime.CompilerServices; using System.Runtime.InteropServices; using System.Text; +using System.Threading; using System.Threading.Tasks; using System.Web; using System.Windows.Documents; @@ -56,29 +59,18 @@ if (e.BarItemKey.ToUpper() == "BTEXPORT") { ExportExcel(); - //this.View.ShowMessage("娴嬭瘯鍟�"); - - string path = PathUtils.GetServerPath(KeyConst.TEMPFILEPATH, PathName); - DynamicFormShowParameter dynamicForm = new DynamicFormShowParameter(); dynamicForm.FormId = "BOS_FileDownLoad"; dynamicForm.OpenStyle.ShowType = ShowType.Modal; dynamicForm.CustomParams.Add("IsExportData", "true"); dynamicForm.CustomParams.Add("url", path); - this.View.ShowForm(dynamicForm); - - - //ShowDownload(); - } - if (e.BarItemKey.ToUpper() == "TBSEARCH") { - SearchList222(); + SearchList(); } - if (e.BarItemKey.ToUpper() == "TBLOCK") { Lock(); @@ -95,16 +87,40 @@ if (e.BarItemKey.ToUpper() == "TBCOMPLETE") { - CompleteSetAnalysis(); + //CompleteSetAnalysis(); //COMPLETEMAIN(); - // COMPLETE(); + COMPLETE(); } //鎻愭枡璁″垝 if (e.BarItemKey.ToUpper() == "TBEXTRACTION") { - Extraction3(); - } + try + { + COMPLETE(); + DayPlanPPBomBill(); + Extraction(); + } + catch (Exception ex) + { + this.View.ShowErrMessage(ex.Message.ToString()); + } + finally { + this.View.ShowMessage("鎿嶄綔鎴愬姛锛�"); + } + + } + //棰勭暀 + if (e.BarItemKey.ToUpper() == "TBRESERVE") + { + Reserve(); + } + //閲婃斁 + if (e.BarItemKey.ToUpper() == "TBRELEASE") + { + + Release(); + } } catch (Exception ex) { @@ -114,7 +130,6 @@ public override void EntryBarItemClick(BarItemClickEventArgs e) { base.EntryBarItemClick(e); - if (e.BarItemKey.ToUpper() == "TBEDIT") { SearchListEdit(); @@ -126,23 +141,25 @@ /// <param name="e"></param> public override void EntityRowDoubleClick(Kingdee.BOS.Core.DynamicForm.PlugIn.Args.EntityRowClickEventArgs e) { - var m = e.Row; - var n = e.Key; base.EntityRowClick(e); + DynamicFormShowParameter formPa = new DynamicFormShowParameter(); - formPa.FormId = "paez_CompleteAnalysisDetail"; - /* jsonModel.Add("FHMainICMOInterID", FMainInterID);//涓荤敓浜ц鍗曚富鍐呯爜 - jsonModel.Add("FHMainICMOEntryID", FMainEntryID);//涓荤敓浜ц鍗曞瓙鍐呯爜 - jsonModel.Add("FHICMOInterID", FDayPlanWorkID);//鏃ヨ鍒掕鍗曚富鍐呯爜 - current["FMatrailId_Id"].ToString(), current["FHMainSourceInterID"].ToString(), current["FHMainSourceEntryID"].ToString(), current["FDayPlanWorkID"].ToString()) - - */ - - formPa.CustomParams.Add("FHMainICMOInterID", Convert.ToString(this.View.Model.GetValue("FHMainSourceInterID", e.Row).ToString())); - formPa.CustomParams.Add("FHMainICMOEntryID", Convert.ToString(this.View.Model.GetValue("FHMainSourceEntryID", e.Row).ToString())); - formPa.CustomParams.Add("FHICMOInterID", Convert.ToString(this.View.Model.GetValue("FDayPlanWorkID", e.Row).ToString())); - formPa.CustomParams.Add("FMatrailId_Id", Convert.ToString((this.View.Model.GetValue("FMatrailId", e.Row) as DynamicObject)["Id"].ToString())); + if (e.ColKey == "FDELAYLNUM") + { + //鐢熶骇璁″垝骞冲彴鎷栨湡鏄庣粏璺宠浆 + formPa.FormId = "paez_TardinessDetails"; + formPa.CustomParams.Add("FID", Convert.ToString(this.View.Model.GetValue("FDayPlanWorkID", e.Row).ToString())); + } + else + { + //榻愬鍒嗘瀽鏄庣粏鍒楄〃璺宠浆 + formPa.FormId = "paez_CompleteAnalysisDetail"; + formPa.CustomParams.Add("FHMainICMOInterID", Convert.ToString(this.View.Model.GetValue("FHMainSourceInterID", e.Row).ToString())); + formPa.CustomParams.Add("FHMainICMOEntryID", Convert.ToString(this.View.Model.GetValue("FHMainSourceEntryID", e.Row).ToString())); + formPa.CustomParams.Add("FHICMOInterID", Convert.ToString(this.View.Model.GetValue("FDayPlanWorkID", e.Row).ToString())); + formPa.CustomParams.Add("FMatrailId_Id", Convert.ToString((this.View.Model.GetValue("FMatrailId", e.Row) as DynamicObject)["Id"].ToString())); + } this.View.ShowForm(formPa); } /// <summary> @@ -254,35 +271,16 @@ public void Lock() { int day = Convert.ToInt32(this.Model.GetValue("FLockDays")); - - string sqlwhere = " and 1=1"; - string FSalOrder = Convert.ToString((this.Model.GetValue("FSalOrder"))); - if (string.IsNullOrEmpty(FSalOrder)) - { - - } - else - sqlwhere += $" and FHSeOrderBillNo='{FSalOrder}'"; - - //鑾峰彇鍗曟嵁浣撲俊鎭� - Entity entity = this.View.BillBusinessInfo.GetEntity("FEntity"); - //鍗曟嵁浣撲俊鎭浆鎹负鍒楄〃闆嗗悎 - DynamicObjectCollection entityDataObjoct = this.View.Model.GetEntityDataObject(entity); List<string> sqlList = new List<string>(); - string sql; - foreach (var item in entityDataObjoct) - { - sql = $"/*dialect*/update t1 set t1.FHLockedSub=1 from Sc_WorkBillSortBillSub t1 join Sc_WorkBillSortBillMain t2 on t1.FID = t2.FID where FHMASTERDATE between DATEADD(day,-1,getdate()) and DATEADD(day,{day - 1},getdate()) and t1.FID = { Convert.ToString(item["FDayPlanWorkID"])} "; - - //sql = $"/*dialect*/update Sc_WorkBillSortBillSub set FHLockedSub=1 where FEntryID in (select TOP({day}) FEntryID from Sc_WorkBillSortBillSub where FHLOCKEDSUB = 0 AND FID = { Convert.ToString(item["FDayPlanWorkID"])} AND DATEDIFF(DAY, GETDATE(), FHMASTERDATE) >= 0 ORDER BY FEntryID) "; - sqlList.Add(sql); - - } - + string sql = $"/*dialect*/update t1 set t1.FHLockedSub=1 from Sc_WorkBillSortBillSub t1 join Sc_WorkBillSortBillMain t2 on t1.FID = t2.FID where FHMASTERDATE between DATEADD(day,-1,getdate()) and DATEADD(day,{day - 1},getdate())"; + sqlList.Add(sql); int result = DBServiceHelper.ExecuteBatch(Context, sqlList); if (result > 0) { - SearchList222(); + //閿佸畾鍚庣敓鎴愭棩璁″垝鐢ㄦ枡娓呭崟 鍙� 鎻愭枡璁″垝 + DayPlanPPBomBill(); + Extraction(); + SearchList(); this.View.ShowMessage("鎿嶄綔鎴愬姛"); } else @@ -294,16 +292,6 @@ public void RelieveLock() { int day = Convert.ToInt32(this.Model.GetValue("FLockDays")); - - string sqlwhere = " and 1=1"; - string FSalOrder = Convert.ToString((this.Model.GetValue("FSalOrder"))); - if (string.IsNullOrEmpty(FSalOrder)) - { - - } - else - sqlwhere += $" and FHSeOrderBillNo='{FSalOrder}'"; - //鑾峰彇鍗曟嵁浣撲俊鎭� Entity entity = this.View.BillBusinessInfo.GetEntity("FEntity"); //鍗曟嵁浣撲俊鎭浆鎹负鍒楄〃闆嗗悎 @@ -313,16 +301,12 @@ foreach (var item in entityDataObjoct) { sql = $"/*dialect*/update t1 set t1.FHLockedSub=0 from Sc_WorkBillSortBillSub t1 join Sc_WorkBillSortBillMain t2 on t1.FID = t2.FID where FHMASTERDATE between DATEADD(day,-1,getdate()) and DATEADD(day,{day - 1},getdate()) and t1.FID = { Convert.ToString(item["FDayPlanWorkID"])} "; - - //sql = $"/*dialect*/update Sc_WorkBillSortBillSub set FHLockedSub=1 where FEntryID in (select TOP({day}) FEntryID from Sc_WorkBillSortBillSub where FHLOCKEDSUB = 0 AND FID = { Convert.ToString(item["FDayPlanWorkID"])} AND DATEDIFF(DAY, GETDATE(), FHMASTERDATE) >= 0 ORDER BY FEntryID) "; sqlList.Add(sql); - } - int result = DBServiceHelper.ExecuteBatch(Context, sqlList); if (result > 0) { - SearchList222(); + SearchList(); this.View.ShowMessage("鎿嶄綔鎴愬姛"); } else @@ -380,7 +364,7 @@ if (result > 0) { this.View.ShowMessage("鎿嶄綔鎴愬姛"); - SearchList222(); + SearchList(); } else this.View.ShowMessage("鎿嶄綔澶辫触锛岃仈绯荤鐞嗗憳锛�"); @@ -392,16 +376,12 @@ /// private void COMPLETE() { - // 鏄剧ず涓�涓繘搴︽樉绀虹晫闈細鏄剧ず涓�涓笉鍋滄粴鍔ㄧ殑妯℃嫙杩涘害 - // bUseTruePro鍙傛暟锛氭槸鍚︽樉绀虹湡瀹炵殑杩涘害銆� // bUseTruePro = false 锛� // 鏄剧ず涓�涓笉鍋滄粴鍔ㄧ殑妯℃嫙杩涘害锛屼笌瀹為檯澶勭悊杩涘害娌℃湁鍏宠仈銆� // 姝ゆ柟妗堜紭鐐癸細瀹為檯澶勭悊浠g爜鏃犻渶璁$畻杩涘害 // 姝ゆ柟妗堢己鐐癸細杩涘害涓嶅噯纭紝涓旇繘搴﹂〉闈笉浼氳嚜鍔ㄥ叧闂�� - - // bUseTruePro = true: 杩涘害鐣岄潰鏄剧ず鐪熷疄杩涘害 // 姝ゆ柟妗堜紭鐐癸細杩涘害鐪熷疄 // 姝ゆ柟妗堢己鐐癸細闇�瑕佸湪澶勭悊浠g爜涓紝涓嶆柇鐨勬洿鏂扮湡瀹炶繘搴︼紝鏇存柊璇彞 @@ -420,15 +400,13 @@ try { // 闇�瑕佹崟鑾烽敊璇紝浠ョ‘淇濆鐞嗙粨鏉熸椂锛屽叧闂繘搴︽粴鍔ㄧ晫闈� - // 寮曞叆鍔熻兘瀹為檯澶勭悊鍑芥暟 - this.COMPLETEMAIN(); + this.CompleteSetAnalysis(); } finally { // 纭繚鏍囪杩涘害宸茬粡鍒拌揪100% this.View.Session["ProcessRateValue"] = 100; - // 寮曞叆瀹屾瘯锛屽叧闂繘搴︽樉绀洪〉闈� var processView = this.View.GetView(processForm.PageId); if (processView != null) @@ -755,6 +733,8 @@ sw.Start();//寮�濮嬭鏃� //娓呯┖榻愬涓存椂琛� DBServiceHelper.Execute(Context, "/*dialect*/ delete JIT_MOMaterReadysBill "); + //鏇存柊鐘舵�� + DBServiceHelper.Execute(Context, "/*dialect*/ update Sc_WorkBillSortBillsub set FCOMPLETE='' "); //鑾峰彇褰撳墠鍗虫椂搴撳瓨 鎸夌収鐗╂枡+搴撳瓨缁勭粐+璐т富+搴撳瓨鏁伴噺 DataSet ds = DBServiceHelper.ExecuteDataSet(Context, @" /*dialect*/ @@ -770,7 +750,7 @@ LEFT JOIN T_STK_Inventory a on T1.FStockOrgId = a.FStockOrgId and T1.FMATERIALID =a.FMATERIALID LEFT JOIN JIT_MOMaterReadysBill B ON T1.FStockOrgId = b.FHSTOCKORGID and T1.FMATERIALID =b.FHMATERID and a.FOwnerId = b.FOwnerId LEFT join T_ORG_Organizations c on a.FOWNERID = c.FORGID -where T1.FMATERIALID in (105773) +--where T1.FMATERIALID in (105773) "); ListInventory = ds.ToModelList<PRD_Inventory>(); //鎬诲簱瀛� 鐗╂枡+搴撳瓨缁勭粐+搴撳瓨鏁伴噺 @@ -787,7 +767,7 @@ ) T1 LEFT JOIN T_STK_Inventory a on T1.FStockOrgId = a.FStockOrgId and T1.FMATERIALID =a.FMATERIALID LEFT JOIN JIT_MOMaterReadysBill B ON T1.FStockOrgId = b.FHSTOCKORGID and T1.FMATERIALID =b.FHMATERID -where T1.FMATERIALID in (105773) +--where T1.FMATERIALID in (105773) group by T1.FStockOrgId,T1.FMATERIALID "); ListInventoryByStockOrgId = ds.ToModelList<PRD_Inventory>(); @@ -795,7 +775,7 @@ string sql = @" /*dialect*/ select a.FPRDMOMAINID,a.FPRDMOENTYID,a.FID,b.FEntryID,a.FHPRDORGID FStockOrgId,t5.FNUMBER as OrgFnumber,a.FHOrderLev,b.FHQTY,b.FHMASTERDATE,T1.FBillNo,T1.FMOBillNO,T1.FMOEntrySeq,T1.FMoId,T1.FMaterialID,T1.FQty, -T2.FMATERIALID FMATERIALID2, T4.FNumber,T2.FNeedQty,FNeedQty/FQty dwyl,FHQTY*(FNeedQty/FQty) PlanCount from SC_WORKBILLSORTBILLMAIN a +T2.FMATERIALID FMATERIALID2, T4.FNumber,T2.FNeedQty,FNeedQty/FQty dwyl,(FHQTY-ISNULL(FProductNum,0))*(FNeedQty/FQty) PlanCount from SC_WORKBILLSORTBILLMAIN a join SC_WORKBILLSORTBILLSub b on a.FID = b.FID join T_PRD_PPBOM T1 on a.FPRDMOMAINID = t1.FMoId and a.FPRDMOENTYID = t1.FMOENTRYID LEFT JOIN(select FID, MAX(FENTRYID) FENTRYID, SUM(FNeedQty) FNeedQty, FMATERIALID from T_PRD_PPBOMENTRY @@ -803,26 +783,28 @@ --LEFT JOIN T_STK_Inventory T3 on t2.FMATERIALID = t3.FMATERIALID JOIN T_BD_MATERIAL T4 on T2.FMATERIALID = T4.FMATERIALID JOIN T_ORG_Organizations t5 on a.FHPRDORGID = t5.FORGID ---where FPRDMOMAINID = 100010 -where t4.FMATERIALID in (105773 -) -ORDER BY b.FHMASTERDATE,a.FHOrderLev "; +--鏉′欢涓轰粖澶╁線鍚庣殑鏃ヨ鍒� + 浠婂ぉ涔嬪墠鏈叧闂殑鏃ヨ鍒� +where (FHEntryCloseDate is null and DATEDIFF(D,GETDATE(),FHMASTERDATE)<0)or DATEDIFF(D,GETDATE(),FHMASTERDATE)>=0 +ORDER BY b.FHMASTERDATE,a.FHOrderLev +"; ds = DBServiceHelper.ExecuteDataSet(Context, sql); List<PRD_PPBOM> BomList = ds.ToModelList<PRD_PPBOM>(); //鏃ヨ鍒�+鐢熶骇璁㈠崟瀛愯〃缂栫爜ID var DatePlanList = BomList.GroupBy(p => new { p.FHMASTERDATE, p.FPRDMOENTYID }).Select(x => new PRD_PPBOM { FHMASTERDATE = x.Key.FHMASTERDATE, FPRDMOENTYID = x.Key.FPRDMOENTYID }).ToList(); //CompleteAnalysisTempModel 鐢ㄤ簬瀛樺偍涓存椂闇�瑕佹彃鍏ユ暟鎹� List<CompleteAnalysisTempModel> completeAnalysisTempModel = new List<CompleteAnalysisTempModel>(); + int i = 1; + //鍒涘缓瀛楀吀 鐢ㄤ簬鍌ㄥ瓨鐗╂枡 + 鍗犵敤鏁伴噺 + Dictionary<string, decimal> occupyDic = new Dictionary<string, decimal>(); foreach (var item in DatePlanList) { + this.View.Session["ProcessRateValue"] = Convert.ToInt32(this.View.Session["ProcessRateValue"]) + Convert.ToInt32((decimal)(1.0 / DatePlanList.Count)); //绛涢�夊嚭褰撴棩璁″垝鏁版嵁 var _BomList = BomList.Where(x => x.FHMASTERDATE == item.FHMASTERDATE && x.FPRDMOENTYID == item.FPRDMOENTYID).ToList(); foreach (var _item in _BomList) { //璇ユ棩璁″垝鐗╂枡闇�瑕佹暟 decimal need = _item.PlanCount; - //瀹為檯鎬诲簱瀛� - decimal sjkc = 0; var sjkcList = ListInventoryByStockOrgId.Where(x => x.FMATERIALID == _item.FMATERIALID2 && x.FStockOrgId == _item.FStockOrgId).FirstOrDefault(); //鐪熸闇�瑕佸彇璁$畻鐨勬暟閲忥紙鎷嗗垎璐т富锛� //璐т富鍖归厤 @@ -832,10 +814,20 @@ decimal _fLackCount = _item.PlanCount > sjkcList.FBASEQTY ? (_item.PlanCount - sjkcList.FBASEQTY) : 0;//缂烘枡鏁伴噺 foreach (var Inventory in _ListInventory) { + if (need == 0) break; decimal fCompleteCount = need >= Inventory.FBASEQTY ? Inventory.FBASEQTY : need;//榻愬鏁伴噺 - //鎬昏鍒掓暟閲� 鍜� 鎬诲簱瀛樻暟閲忔瘮瀵� + decimal occupyMaterial = 0; + if (!occupyDic.ContainsKey(_item.FMATERIALID2)) + { + occupyDic.Add(_item.FMATERIALID2, fCompleteCount); + } + else + { + occupyMaterial = occupyDic[_item.FMATERIALID2]; + occupyDic[_item.FMATERIALID2] = occupyMaterial + fCompleteCount; + } completeAnalysisTempModel.Add(new Demo.Model.Model.CompleteAnalysisTempModel { FHMainICMOInterIDr = _item.FPRDMOMAINID, @@ -854,6 +846,7 @@ FLackCount = _fLackCount,//缂烘枡鏁伴噺 FHStockQty = sjkcList.FBASEQTY,//鍗虫椂搴撳瓨 FHLeftQty = Inventory.FBASEQTY,//鍙敤鏁伴噺 + FOccupyCount = occupyMaterial,//鍗犵敤鏁伴噺 FComPlete = sjkcList.FBASEQTY >= _item.PlanCount ? "榻愬" : "鏈綈濂�", FPlanDate = item.FHMASTERDATE // 鏃ヨ鍒掓棩鏈� }); @@ -867,6 +860,9 @@ } else { + decimal occupyMaterial = 0; + if (occupyDic.ContainsKey(_item.FMATERIALID2)) + occupyMaterial = occupyDic[_item.FMATERIALID2]; completeAnalysisTempModel.Add(new Demo.Model.Model.CompleteAnalysisTempModel { FHMainICMOInterIDr = _item.FPRDMOMAINID, @@ -884,14 +880,21 @@ FLackCount = _item.PlanCount,//缂烘枡鏁伴噺 FHStockQty = 0,//鍗虫椂搴撳瓨 FHLeftQty = 0,//鍙敤鏁伴噺 + FOccupyCount = occupyMaterial,//鍗犵敤鏁伴噺 FComPlete = "鏈綈濂�", FPlanDate = item.FHMASTERDATE // 鏃ヨ鍒掓棩鏈� }); } } + //Thread.Sleep(100); + this.View.Session["ProcessRateValue"] = Convert.ToInt32((Convert.ToDecimal(40) / DatePlanList.Count) * i); + i++; + } + i = 1; foreach (var item in completeAnalysisTempModel) { + // this.View.Session["ProcessRateValue"] = Convert.ToInt32(this.View.Session["ProcessRateValue"]) + Convert.ToInt32(1 / completeAnalysisTempModel.Count * 90); JObject jsonRoot = new JObject(); jsonRoot.Add("Creator", ""); jsonRoot.Add("NeedUpDateFields", new JArray()); @@ -917,6 +920,7 @@ jsonModel.Add("FOwnerTypeId", item.FOwnerTypeId); jsonModel.Add("FComPlete", item.FComPlete); jsonModel.Add("FLackCount", item.FLackCount); + jsonModel.Add("FOccupyCount", item.FOccupyCount); jsonModel.Add("FPlanDate", item.FPlanDate); if (item.FOwnerId != null) jsonModel.Add("FOwnerId", new JObject() { ["FNUMBER"] = item.FOwnerId }); @@ -929,6 +933,8 @@ { LogHelper.Error(jsonRoot.ToString()); } + this.View.Session["ProcessRateValue"] = 40 + Convert.ToInt32((Convert.ToDecimal(60) / completeAnalysisTempModel.Count) * i); + i++; } //鎵ц瀹屾垚鍚� 鏇存柊鏃ヨ鍒掑伐鍗曠姸鎬� DBServiceHelper.Execute(Context, @" @@ -948,10 +954,9 @@ /// <summary> /// 鏌ヨ /// </summary> - public void SearchList222() + public void SearchList() { string sqlwhere = " where 1=1"; - if ((this.Model.GetValue("FProWorkShopId") as DynamicObject) != null) { string FProWorkShopId = (this.Model.GetValue("FProWorkShopId") as DynamicObject)["Id"].ToString(); @@ -960,23 +965,12 @@ } //閿�鍞鍗曞彿 string FSalOrder = Convert.ToString((this.Model.GetValue("FSalOrder"))); - if (string.IsNullOrEmpty(FSalOrder)) - { - - } - else + if (!string.IsNullOrEmpty(FSalOrder)) sqlwhere += $" and FHSeOrderBillNo='{FSalOrder}'"; - - //鐢熶骇璁㈠崟鍙� string FScOrderMainNo = Convert.ToString((this.Model.GetValue("FScOrderMainNo"))); - if (string.IsNullOrEmpty(FScOrderMainNo)) - { - - } - else + if (!string.IsNullOrEmpty(FScOrderMainNo)) sqlwhere += $" and FSCORDERNO='{FScOrderMainNo}'"; - //鐗╂枡 if ((this.Model.GetValue("FMatralId") as DynamicObject) != null) { @@ -988,12 +982,10 @@ string FPreparatDate = Convert.ToString((this.Model.GetValue("FPreparatDate"))); if (!string.IsNullOrEmpty(FPreparatDate)) sqlwhere += $" and FPreparatDate='{FPreparatDate}'"; - - try { - string sql = @"/*dialect*/select t1.* from Sc_WorkBillSortBillMain t1 - left join T_BD_MATERIAL t3 on t1.FHMaterID=t3.FMATERIALID + string sql = @"/*dialect*/ select t1.*,isnull((select SUM(isnull(FNotProductNum,0)) from SC_WORKBILLSORTBILLSub t2 where t2.FID = t1.FID and DATEDIFF(D,FHMASTERDATE,GETDATE())>0),0)FNotProductNum from Sc_WorkBillSortBillMain t1 + left join T_BD_MATERIAL t3 on t1.FHMaterID=t3.FMATERIALID " + sqlwhere; DataTable dt = DBServiceHelper.ExecuteDataSet(Context, sql).Tables[0]; DateTime DateNow = DateTime.Now;//鑾峰彇褰撳墠鏃ユ湡 @@ -1019,26 +1011,17 @@ this.Model.SetValue("FHMainSourceInterID", dt.Rows[i]["FPRDMOMAINID"].ToString(), i);//婧愬崟涓诲唴鐮丗HMainSourceInterID this.Model.SetValue("FHMainSourceEntryID", dt.Rows[i]["FPRDMOENTYID"].ToString(), i);//婧愬崟瀛愬唴鐮丗HMainSourceEntryID this.Model.SetValue("FDayPlanWorkID", dt.Rows[i]["FID"].ToString(), i);//鏃ヨ鍒掑伐鍗旻ID - this.Model.SetValue("FResourcesId", dt.Rows[i]["FHSourceID"].ToString(), i);//鐢熶骇璧勬簮 this.Model.SetValue("FProductWorkShopId", dt.Rows[i]["FHWorkShopID"].ToString(), i);//鐢熶骇杞﹂棿 - this.Model.SetValue("FCompleteSetCount", dt.Rows[i]["FCompleteCount"].ToString(), i);//榻愬鏁伴噺 this.Model.SetValue("FOrderQuantity", dt.Rows[i]["FOrderQuantity"].ToString(), i);//鐢熶骇璁㈠崟鏁伴噺 this.Model.SetValue("FDayPlanQuantity", dt.Rows[i]["FDayPlanQuantity"].ToString(), i);//鏃ヨ鍒掓暟閲� this.Model.SetValue("FNoScheduled", dt.Rows[i]["FNoScheduled"].ToString(), i);//鏈帓鏁伴噺 - - + this.Model.SetValue("FDelaylnUM", dt.Rows[i]["FNotProductNum"].ToString(), i);//鎷栨湡鏁伴噺 sql = @"/*dialect*/SELECT * FROM Sc_WorkBillSortBillSub WHERE DATEDIFF(D,GETDATE(),FHMASTERDATE)>=0 and FID=" + dt.Rows[i]["FID"].ToString(); DataTable _dt = DBServiceHelper.ExecuteDataSet(Context, sql).Tables[0]; - foreach (DataRow dr in _dt.Rows) { - /* - this.Model.SetValue(dr["FColumn"].ToString(), dr["FHQTY"].ToString(), i);//鏃ヨ鍒掑伐鍗旻ID - if (dr["FHLockedSub"].ToString() == "1") - this.View.GetFieldEditor(dr["FColumn"].ToString(), i).Enabled = false; //鍗曟嵁浣撹閿佸畾瀛楁 - */ DateTime start = Convert.ToDateTime(DateNow.ToShortDateString()); DateTime end = Convert.ToDateTime(Convert.ToDateTime(dr["FHMASTERDATE"]).ToShortDateString()); TimeSpan getDay = end.Subtract(start); @@ -1077,7 +1060,6 @@ } } } - for (int m = 0; m <= 60; m++) { this.View.GetControl("FT" + "" + m + "").Text = DateNow.AddDays(m).ToShortDateString(); @@ -1087,9 +1069,6 @@ { this.View.ShowErrMessage(ex.Message.ToString()); } - - - } /// <summary> /// 缂栬緫 @@ -1134,8 +1113,8 @@ sqlwhere += $" and FPreparatDate='{FPreparatDate}'"; try { - string sql = @"/*dialect*/select t1.* from Sc_WorkBillSortBillMain t1 - left join T_BD_MATERIAL t3 on t1.FHMaterID=t3.FMATERIALID + string sql = @"/*dialect*/ select t1.*,isnull((select SUM(isnull(FNotProductNum,0)) from SC_WORKBILLSORTBILLSub t2 where t2.FID = t1.FID and DATEDIFF(D,FHMASTERDATE,GETDATE())>0),0)FNotProductNum from Sc_WorkBillSortBillMain t1 + left join T_BD_MATERIAL t3 on t1.FHMaterID=t3.FMATERIALID " + sqlwhere; DataTable dt = DBServiceHelper.ExecuteDataSet(Context, sql).Tables[0]; DateTime DateNow = DateTime.Now;//鑾峰彇褰撳墠鏃ユ湡 @@ -1167,6 +1146,7 @@ this.Model.SetValue("FOrderQuantity", dt.Rows[i]["FOrderQuantity"].ToString(), i);//鐢熶骇璁㈠崟鏁伴噺 this.Model.SetValue("FDayPlanQuantity", dt.Rows[i]["FDayPlanQuantity"].ToString(), i);//鏃ヨ鍒掓暟閲� this.Model.SetValue("FNoScheduled", dt.Rows[i]["FNoScheduled"].ToString(), i);//鏈帓鏁伴噺 + this.Model.SetValue("FDelaylnUM", dt.Rows[i]["FNotProductNum"].ToString(), i);//鎷栨湡鏁伴噺 sql = @"/*dialect*/SELECT * FROM Sc_WorkBillSortBillSub WHERE DATEDIFF(D,GETDATE(),FHMASTERDATE)>=0 and FID=" + dt.Rows[i]["FID"].ToString(); DataTable _dt = DBServiceHelper.ExecuteDataSet(Context, sql).Tables[0]; foreach (DataRow dr in _dt.Rows) @@ -1214,35 +1194,23 @@ /// </summary> public void Extraction3() { + string sql = string.Format(@"/*dialect*/ select t1.FID from Sc_WorkBillSortBillMain t1"); + DataTable fidDt = DBServiceHelper.ExecuteDataSet(Context, sql).Tables[0]; + string FDayPlanWorkID = ""; + foreach (DataRow dr in fidDt.Rows) + { + FDayPlanWorkID += Convert.ToString(dr["FID"]) + ","; + } - //鑾峰彇鍗曟嵁浣撲俊鎭� - Entity entity = this.View.BillBusinessInfo.GetEntity("FEntity"); - //鍗曟嵁浣撲俊鎭浆鎹负鍒楄〃闆嗗悎 - DynamicObjectCollection entityDataObjoct = this.View.Model.GetEntityDataObject(entity); - EntryGrid grid = this.View.GetControl<EntryGrid>("FEntity"); - string FDayPlanWorkID = "";//鏃ュ伐鍗旾D - if (entityDataObjoct.Count == 0) - { - this.View.ShowMessage("璇峰厛鍔犺浇鏁版嵁锛�"); - return; - } - else - { - foreach (DynamicObject current in entityDataObjoct) - { - FDayPlanWorkID += Convert.ToString(current["FDayPlanWorkID"]) + ","; - } - } FDayPlanWorkID = FDayPlanWorkID.Substring(0, FDayPlanWorkID.Length - 1); //鎻愭枡璁″垝棰勫鐞� 娓呯悊鎻愭枡璁″垝鍗曟暟鎹� 鏇存柊閲囪喘璁㈠崟鎻愭枡璁″垝鏁伴噺 - string sql = string.Format(@" - /*dialect*/ + sql = string.Format(@" + exec [鎻愭枡璁″垝棰勫鐞哴 '{0}' ", FDayPlanWorkID.Replace(",", "-")); DBServiceHelper.Execute(Context, sql); - //閲囪喘璁㈠崟鏁版嵁 sql = @" /*dialect*/ @@ -1257,10 +1225,9 @@ List<PurchaseInventory> PurchaseInventory = DBServiceHelper.ExecuteDataSet(Context, sql).ToModelList<PurchaseInventory>(); LogHelper.Info("閲囪喘璁㈠崟鏁版嵁" + sql); - sql = string.Format(@" /*dialect*/ - SELECT T1.FID,FHMATERID,FHMASTERDATE,FHQTY,FCOMPLETECOUNT,FPRDMOMAINID,T2.FENTRYID,T1.FBILLNO, FNeedQty,t5.FFIXLEADTIME,t5.FMAXPOQTY,t5.FMINPOQTY,t3.FMATERIALID,t6.FNumber,FHQTY*FNeedQty NeedQty,FHPRDORGID FStockOrgId FROM SC_WORKBILLSORTBILLMAIN T1 + SELECT T1.FID,FHMATERID,FHMASTERDATE,FHQTY,FCOMPLETECOUNT,FPRDMOMAINID,T2.FENTRYID,T1.FBILLNO, FNeedQty,(FLeadtime+FLeadTtime2)FFIXLEADTIME,t5.FMAXPOQTY,FJITBatch FMINPOQTY,FJITMATERIALGROUP,FJITMaterielDemand,FJITSafeStock,t3.FMATERIALID,t6.FNumber,FHQTY*FNeedQty NeedQty,FHPRDORGID FStockOrgId FROM SC_WORKBILLSORTBILLMAIN T1 JOIN SC_WORKBILLSORTBILLSUB T2 ON T1.FID=T2.FID LEFT JOIN(SELECT T1.FID,max(t2.FMATERIALID)FMATERIALIDMAIN, max(t2.FMoId)FMoId,MAX(FENTRYID) FENTRYID, SUM(convert(decimal(18, 2), FBASENUMERATOR / FBASEDENOMINATOR))FNeedQty, T1.FMATERIALID from T_PRD_PPBOMENTRY T1 JOIN T_PRD_PPBOM T2 on t1.FID = t2.FID @@ -1271,7 +1238,7 @@ WHERE DATEDIFF(D,GETDATE(),FHMASTERDATE) >=0 AND FDayPlanQuantity>FCOMPLETECOUNT AND FERPCLSID=1 -AND T2.FENTRYID not in (select distinct FHSOURCEENTRYID from CG_PODEMANDPLANBILLSUB where FHSOURCEINTERID IN ({0})) + AND T2.FENTRYID not in (select distinct FHSOURCEENTRYID from CG_PODEMANDPLANBILLSUB where FHSOURCEINTERID IN ({0})) AND T1.FID in ({0}) order by FHMASTERDATE ", FDayPlanWorkID); @@ -1311,9 +1278,6 @@ { DayPlanPpbom.RemoveAll(p => p.FENTRYID == item.FENTRYID && p.FMATERIALID == item.FMATERIALID); } - - - sql = @"select T1.FID,FDayPlanQuantity,FCOMPLETECOUNT,t2.FHQTY, FHPRDORGID FStockOrgId from SC_WORKBILLSORTBILLMAIN T1 JOIN SC_WORKBILLSORTBILLSUB T2 ON T1.FID=T2.FID WHERE DATEDIFF(D,GETDATE(),FHMASTERDATE) >=0 AND FDayPlanQuantity>FCOMPLETECOUNT AND T1.FID in (" + FDayPlanWorkID + ")"; DataSet Complete = DBServiceHelper.ExecuteDataSet(Context, sql); @@ -1705,7 +1669,684 @@ this.View.ShowMessage("鎿嶄綔鎴愬姛"); // var PODemandPlanList22 = PODemandPlanTemp.GroupBy(p => new {p.FSUPPLIERID, p.FHMASTERDATE }).ToList(); } + /// <summary> + /// 鏃ヨ鍒掔敤鏂欐竻鍗曠敓鎴� + /// </summary> + public void DayPlanPPBomBill() + { + //閿佸畾鐨勬棩璁″垝涓嶇敓鎴� + try + { + string sql = string.Format(@" +/*dialect*/ +select t1.FID,t1.FEntryID,t3.FMATERIALID,T5.FNUMBER,t1.FHMASTERDATE,t1.FHQTY,t4.FMATERIALID FMATERIALID2,T6.FNUMBER FNUMBER2,T7.FNUMBER FUNITNUMBER,FNumerator,FDenominator,convert(decimal(18,2),(FNumerator/FDenominator) *t1.FHQTY) FHQtyMust,T4.FUnitID,t8.FNUMBER FUNITNUMBER2,T3.FID FPPBOM,T4.FENTRYID,isnull(T9.FBillNo,'')FBillNo,t10.FNUMBER FORGNUMBER,t11.FNUMBER FHSOURCENUMBER,FSCRAPRATE,FFIXSCRAPQTY,T9.FID AS DayPlanFID +FROM Sc_WorkBillSortBillSub t1 +JOIN Sc_WorkBillSortBillMAIN t2 on t1.FID = t2.FID +JOIN T_PRD_PPBOM T3 on T2.FPRDMOMAINID=t3.FMOID AND T2.FPRDMOENTYID=T3.FMOENTRYID +JOIN T_PRD_PPBOMENTRY T4 ON T3.FID=T4.FID +JOIN T_BD_MATERIAL T5 ON T3.FMATERIALID=T5.FMATERIALID +JOIN T_BD_MATERIAL T6 ON T4.FMATERIALID=T6.FMATERIALID +LEFT JOIN T_BD_UNIT T7 ON T3.FUNITID = T7.FUNITID +LEFT JOIN T_BD_UNIT T8 ON T4.FUNITID = T8.FUNITID + LEFT JOIN Sc_DayPlanPPBomBillMain T9 ON T1.FEntryID=T9.FDayPlanFID + LEFT join T_ORG_Organizations t10 on t2.FHPRDORGID = t10.FORGID + LEFT join T_ENG_WORKCENTER t11 on t2.FHSOURCEID = t11.FID +" +); + DataSet ds = DBServiceHelper.ExecuteDataSet(Context, sql); + DataTable dt = ds.Tables[0]; + List<DayPlanMaterial> DayPlanMaterial = new List<DayPlanMaterial>(); + if (dt.Rows.Count > 0) + { + foreach (DataRow dr in dt.Rows) + { + DayPlanMaterial.Add(new Demo.Model.Model.DayPlanMaterial + { + FID = dr["DayPlanFID"].ToString(), + FEntryID = dr["FEntryID"].ToString(), + FHDate = DateTime.Now.ToString(), + FOrgId = dr["FORGNUMBER"].ToString(), + FHMaterID = dr["FNUMBER"].ToString(), + FHWorkDate = dr["FHMASTERDATE"].ToString(), + FHQty = dr["FHQTY"].ToString(), + FHUnitID = dr["FUNITNUMBER"].ToString(), + FDayPlanFID = dr["FEntryID"].ToString(), + FHMaterSubID = dr["FNUMBER2"].ToString(), + FHUnitSubID = dr["FUNITNUMBER2"].ToString(), + FHQtyMust = dr["FHQtyMust"].ToString(), + FHQtySub = dr["FHQtyMust"].ToString(), + FHPPBomInterID = dr["FPPBOM"].ToString(), + FHPPBomEntryID = dr["FENTRYID"].ToString(), + FHSourceID = dr["FHSOURCENUMBER"].ToString(), + FNumerator = dr["FNumerator"].ToString(), + FDenominator = dr["FDenominator"].ToString(), + FFIXSCRAPQTY = dr["FFIXSCRAPQTY"].ToString(), + FHQtyScrap = dr["FSCRAPRATE"].ToString(), + }); + } + var fidList = DayPlanMaterial.Select(x => x.FEntryID).Distinct().ToList(); + foreach (var item in fidList) + { + var _DayPlanMaterial = DayPlanMaterial.Where(x => x.FEntryID == item).ToList(); + JObject model = new JObject(); + model.Add("FHDate", DateTime.Now); + model.Add("FOrgId", new JObject() { ["Fnumber"] = _DayPlanMaterial[0].FOrgId });//鍙戞枡缁勭粐 + model.Add("FHMaterID", new JObject() { ["Fnumber"] = _DayPlanMaterial[0].FHMaterID });//鐗╂枡 + model.Add("FHWorkDate", _DayPlanMaterial[0].FHWorkDate);//鏃ュ伐鍗曟棩鏈� FHWorkDate + model.Add("FHQty", _DayPlanMaterial[0].FHQty);//涓讳骇鍝佹暟閲忥細FHQty + model.Add("FHUnitID", new JObject() { ["Fnumber"] = _DayPlanMaterial[0].FHUnitID });//鍗曚綅锛欶HUnitID + model.Add("FDayPlanFID", _DayPlanMaterial[0].FDayPlanFID);//鏃ヨ鍒掑伐鍗曞唴鐮� + JArray Entry = new JArray(); + foreach (var _item in _DayPlanMaterial) + { + JObject ModelEnty = new JObject(); + ModelEnty.Add("FHMaterSubID", new JObject() { ["Fnumber"] = _item.FHMaterSubID });//瀛愮墿鏂橣HMaterSubID + ModelEnty.Add("FHUnitSubID", new JObject() { ["Fnumber"] = _item.FHUnitSubID });//鍗曚綅FHUnitSubID + ModelEnty.Add("FHQtyMust", _item.FHQtyMust);//搴斿彂鏁伴噺FHQtyMust + ModelEnty.Add("FHQtySub", _item.FHQtySub);//鏁伴噺FHQtySub + ModelEnty.Add("FHPPBomInterID", _item.FHPPBomInterID);//鐢ㄦ枡娓呭崟涓诲唴鐮丗HPPBomInterID + ModelEnty.Add("FHPPBomEntryID", _item.FHPPBomEntryID);//鐢ㄦ枡娓呭崟瀛愬唴鐮丗HPPBomEntryID + ModelEnty.Add("FHSourceID", new JObject() { ["Fnumber"] = _item.FHSourceID });//鐢熶骇璧勬簮FHSourceID + ModelEnty.Add("FNumerator", _item.FNumerator);//鍒嗘瘝 + ModelEnty.Add("FDenominator", _item.FDenominator);//鍒嗗瓙 + ModelEnty.Add("FFIXSCRAPQTY", _item.FFIXSCRAPQTY);//鍥哄畾鎹熻�� + ModelEnty.Add("FHQtyScrap", _item.FHQtyScrap);//鍙樺姩鎹熻�楃巼% + Entry.Add(ModelEnty); + } + model.Add("FEntity", Entry); + if (!string.IsNullOrEmpty(_DayPlanMaterial[0].FID)) + model.Add("FID", _DayPlanMaterial[0].FID); + JObject jsonRoot = new JObject() + { + ["Creator"] = "", + ["NeedUpDateFields"] = new JArray(), + ["NeedReturnFields"] = new JArray(), + ["IsDeleteEntry"] = "true", + ["SubSystemId"] = "", + ["IsVerifyBaseDataField"] = "false", + ["Model"] = model + }; + + CloudClient cloudClient = new CloudClient("http://localhost/K3Cloud/"); + var result = cloudClient.Save("Paez_Sc_DayPlanPPBomBill", jsonRoot.ToString()); + JObject saveObj = JObject.Parse(result); + string saveIsSuc = saveObj["Result"]["ResponseStatus"]["IsSuccess"].ToString().ToUpper(); + if (saveIsSuc != "TRUE") + LogHelper.Error(saveIsSuc); + } + } + } + catch (Exception ex) + { + LogHelper.Error(ex.Message.ToString()); + } + } + /// <summary> + /// 鎻愭枡璁″垝 + /// </summary> + public void Extraction() + { + string sql = string.Format(@"/*dialect*/ select t1.FID from Sc_WorkBillSortBillMain t1"); + DataTable fidDt = DBServiceHelper.ExecuteDataSet(Context, sql).Tables[0]; + string FDayPlanWorkID = ""; + foreach (DataRow dr in fidDt.Rows) + { + FDayPlanWorkID += Convert.ToString(dr["FID"]) + ","; + } + + FDayPlanWorkID = FDayPlanWorkID.Substring(0, FDayPlanWorkID.Length - 1); + + //鎻愭枡璁″垝棰勫鐞� 娓呯悊鎻愭枡璁″垝鍗曟暟鎹� 鏇存柊閲囪喘璁㈠崟鎻愭枡璁″垝鏁伴噺 + sql = string.Format(@" + /*dialect*/ + exec [鎻愭枡璁″垝棰勫鐞哴 '{0}' + ", FDayPlanWorkID.Replace(",", "-")); + + DBServiceHelper.Execute(Context, sql); + //閲囪喘璁㈠崟鏁版嵁 + sql = @" + /*dialect*/ +select t1.FID,t1.FBillNo,t2.FENTRYID,t1.FSUPPLIERID,t3.fnumber,t2.FMATERIALID,(t2.FQTY-t2.FPODemandPlanCount)FQTY,FPurchaseOrgId FStockOrgId,t5.FNUMBER FORGNumber,FSTOCKINQTY,FReceiveQty,FCloseStatus,FMRPCLOSESTATUS from t_PUR_POOrder t1 +join t_PUR_POOrderEntry t2 on t1.FID = t2.FID +join t_BD_Supplier t3 on t1.FSUPPLIERID = t3.FSUPPLIERID +join T_PUR_POORDERENTRY_R t4 on t2.FENTRYID = t4.FENTRYID +join T_ORG_Organizations t5 on t1.FPurchaseOrgId = t5.FORGID +where t2.FQTY-t2.FPODemandPlanCount>0 + and FCloseStatus in('A') and FMRPCLOSESTATUS in('A') +"; + List<PurchaseInventory> PurchaseInventory = DBServiceHelper.ExecuteDataSet(Context, sql).ToModelList<PurchaseInventory>(); + LogHelper.Info("閲囪喘璁㈠崟鏁版嵁" + sql); + + sql = string.Format(@" + /*dialect*/ + SELECT T1.FID,FHMATERID,FHMASTERDATE,FHQTY,FCOMPLETECOUNT,FPRDMOMAINID,T2.FENTRYID,T1.FBILLNO, FNeedQty,(FLeadtime+FLeadTtime2)FFIXLEADTIME,t5.FMAXPOQTY,FJITBatch FMINPOQTY,FJITMATERIALGROUP,FJITMaterielDemand,FJITSafeStock,t3.FMATERIALID,t6.FNumber,FHQTY*FNeedQty NeedQty,FHPRDORGID FStockOrgId FROM SC_WORKBILLSORTBILLMAIN T1 +JOIN SC_WORKBILLSORTBILLSUB T2 ON T1.FID=T2.FID +LEFT JOIN(SELECT T1.FID,max(t2.FMATERIALID)FMATERIALIDMAIN, max(t2.FMoId)FMoId,MAX(FENTRYID) FENTRYID, SUM(convert(decimal(18, 2), FBASENUMERATOR / FBASEDENOMINATOR))FNeedQty, T1.FMATERIALID from T_PRD_PPBOMENTRY T1 +JOIN T_PRD_PPBOM T2 on t1.FID = t2.FID +group by T1.FMATERIALID, T1.FID) T3 on T1.FPRDMOMAINID = t3.FMoId and T1.FHMATERID = t3.FMATERIALIDMAIN +JOIN T_BD_MATERIAL T6 ON T3.FMATERIALID = T6.FMATERIALID +join t_BD_MaterialBase t4 on t3.FMATERIALID = t4.FMATERIALID +join t_BD_MaterialPlan t5 on t3.FMATERIALID = t5.FMATERIALID +WHERE DATEDIFF(D,GETDATE(),FHMASTERDATE) >=0 +AND FDayPlanQuantity>FCOMPLETECOUNT +AND FERPCLSID=1 + AND T2.FENTRYID not in (select distinct FHSOURCEENTRYID from CG_PODEMANDPLANBILLSUB where FHSOURCEINTERID IN ({0})) +AND T1.FID in ({0}) +order by FHMASTERDATE +", FDayPlanWorkID); + LogHelper.Info("鎻愭枡鏁版嵁" + sql); + DataSet ds = DBServiceHelper.ExecuteDataSet(Context, sql); + List<DayPlanPpbom> DayPlanPpbom = ds.ToModelList<DayPlanPpbom>(); + + var MaterialIDList = DayPlanPpbom.GroupBy(p => new { p.FMATERIALID, p.FStockOrgId }).Select(x => new PODemandPlanTemp { FMATERIALID = x.Key.FMATERIALID, FStockOrgId = x.Key.FStockOrgId }).ToList(); + var _MaterialIDList = MaterialIDList.Where(p => p.FMATERIALID == "105773").ToList(); + + LogHelper.Info("鐗╂枡琛屾暟" + MaterialIDList.Count); + + //鎻愭枡璁″垝鏁版嵁闆嗕复鏃跺瓨鍌ㄩ泦鍚� + List<PODemandPlanTemp> PODemandPlanTemp = new List<PODemandPlanTemp>(); + //sql闆嗗悎 鏇存柊閲囪喘璁㈠崟鍗犵敤鐨勬彁鏂欒鍒掓暟閲� + List<string> sqlList = new List<string>(); + //MaterialIDList = new List<string> { "105773" }; + foreach (var item in MaterialIDList) + { + LogHelper.Info(item.FMATERIALID.ToString()); + List<DayPlanPpbom> _DayPlanPpbom = DayPlanPpbom.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId).ToList(); + + decimal FMINPOQTY = _DayPlanPpbom.FirstOrDefault().FMINPOQTY;//鏈�灏忚捣璁㈤噺 + double FFIXLEADTIME = _DayPlanPpbom.FirstOrDefault().FFIXLEADTIME;//鎻愬墠鏈� + string FJITmaterialGroup = _DayPlanPpbom.FirstOrDefault().FJITmaterialGroup;//jit鐗╂枡鍒嗙被 + string FJITMaterielDemand = _DayPlanPpbom.FirstOrDefault().FJITMaterielDemand; //JIT鐗╂枡闇�姹備緵璐у懆鏈� + string FJITSafeStock = _DayPlanPpbom.FirstOrDefault().FJITSafeStock; //JIT瀹夊叏搴撳瓨 + decimal NeedQty = 0; + DateTime DATE = _DayPlanPpbom.FirstOrDefault().FHMASTERDATE; + int i = 1; + //璁板綍鍦ㄦ渶灏忛噰璐噺闇�姹備笅鐨勬棩璁″垝鏄庣粏FentyrID + List<int> FEntryIdList = new List<int>(); + foreach (var _item in _DayPlanPpbom) + { + if (NeedQty == 0) + DATE = Convert.ToDateTime(_item.FHMASTERDATE).AddDays(-FFIXLEADTIME); + FEntryIdList.Add(_item.FENTRYID); + NeedQty += _item.NeedQty; + if ((FJITmaterialGroup == "鎬婚噺鎺у埗瑙勬牸绫�" || FJITmaterialGroup == "璁㈠崟涓撶敤涓�х被") && FEntryIdList.Count < Convert.ToInt32(FJITMaterielDemand)) //璁㈠崟涓撶敤涓�х被 + continue; + if (NeedQty >= FMINPOQTY) + { + List<PurchaseInventory> _PurchaseInventory = PurchaseInventory.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId && x.FQTY > 0).ToList(); + if (_PurchaseInventory.Count == 0) + { + NeedQty = 0; + break; + } + foreach (var Purchase in _PurchaseInventory) + { + LogHelper.Info("Purchase"); + LogHelper.Info("鐗╂枡锛�" + Purchase.FMATERIALID + ",鏁伴噺锛�" + Purchase.FQTY); + if (Purchase.FQTY >= NeedQty) + { + List<int> mmm = new List<int>(); + foreach (int id in FEntryIdList) + { + mmm.Add(id); + var DayPlanPpbomls = DayPlanPpbom.Where(c => c.FENTRYID == id && c.FMATERIALID == _item.FMATERIALID).FirstOrDefault(); + PODemandPlanTemp.Add(new Demo.Model.Model.PODemandPlan.PODemandPlanTemp + { + FID = DayPlanPpbomls.FID, + FHMASTERDATE = DATE, + FQty = DayPlanPpbomls.NeedQty, + FBILLNO = DayPlanPpbomls.FBILLNO, + FENTRYID = DayPlanPpbomls.FENTRYID, + FMATERIALID = DayPlanPpbomls.FMATERIALID, + FNumber = DayPlanPpbomls.FNumber, + OLDDATE = DayPlanPpbomls.FHMASTERDATE, + FFIXLEADTIME = FFIXLEADTIME, + + PurchseFID = Purchase.FID, + PurchseFentryID = Purchase.FENTRYID, + FSUPPLIERID = Purchase.FSUPPLIERID, + PurchseFNUMBER = Purchase.FNUMBER, + PurchseFBillNo = Purchase.FBillNo, + PurchseFqty = Purchase.FQTY, + FStockOrgId = Purchase.FStockOrgId, //閲囪喘缁勭粐 + FORGNumber = Purchase.FORGNumber + }); + //鎵i櫎鏃ヨ鍒掓槑缁嗗凡琚垎閰嶇殑鏁伴噺 + DayPlanPpbomls.NeedQty = 0; + } + FEntryIdList.Clear(); + //鏇存柊閲囪喘璁㈠崟 + sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount =isnull(FPODemandPlanCount,0)+ '{NeedQty}' where FENTRYID = {Purchase.FENTRYID}"); + //鎵i櫎褰撳墠琛屽搴旈噰璐鍗曟暟閲� + var ls = PurchaseInventory.Where(c => c.FENTRYID == Purchase.FENTRYID).FirstOrDefault(); + ls.FQTY -= NeedQty; + break; + } + else + { + NeedQty = NeedQty - Purchase.FQTY; + decimal _NeedQty = Purchase.FQTY;//閲囪喘璁㈠崟鏁伴噺 + List<int> mmm = new List<int>(); + foreach (int id in FEntryIdList) + { + var DayPlanPpbomls = DayPlanPpbom.Where(c => c.FENTRYID == id && c.FMATERIALID == _item.FMATERIALID).FirstOrDefault(); + decimal Qty = DayPlanPpbomls.NeedQty; + if (Qty > _NeedQty) + Qty = _NeedQty; + _NeedQty = _NeedQty - DayPlanPpbomls.NeedQty; + PODemandPlanTemp.Add(new Demo.Model.Model.PODemandPlan.PODemandPlanTemp + { + FID = DayPlanPpbomls.FID, + FHMASTERDATE = DATE, + FQty = Qty, + FBILLNO = DayPlanPpbomls.FBILLNO, + FENTRYID = DayPlanPpbomls.FENTRYID, + FMATERIALID = DayPlanPpbomls.FMATERIALID, + FNumber = DayPlanPpbomls.FNumber, + OLDDATE = DayPlanPpbomls.FHMASTERDATE, + FFIXLEADTIME = FFIXLEADTIME, + + PurchseFID = Purchase.FID, + PurchseFentryID = Purchase.FENTRYID, + FSUPPLIERID = Purchase.FSUPPLIERID, + PurchseFNUMBER = Purchase.FNUMBER, + PurchseFBillNo = Purchase.FBillNo, + PurchseFqty = Purchase.FQTY, + FStockOrgId = Purchase.FStockOrgId, //閲囪喘缁勭粐 + FORGNumber = Purchase.FORGNumber + }); + DayPlanPpbomls.NeedQty -= Qty; + //鏇存柊閲囪喘璁㈠崟 + sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount = isnull(FPODemandPlanCount,0)+ '{Qty}' where FENTRYID = {Purchase.FENTRYID}"); + //鏇存柊Model + var ls = PurchaseInventory.Where(c => c.FENTRYID == Purchase.FENTRYID).FirstOrDefault(); + ls.FQTY -= Qty; + if (_NeedQty < 0) + { + foreach (var mm in mmm) + { + FEntryIdList.Remove(mm); + } + break; + } + mmm.Add(id); + } + foreach (var mm in mmm) + { + FEntryIdList.Remove(mm); + } + } + } + NeedQty = 0; + } + + #region 鍓╀笅涓嶈冻鏃舵寜鏈�灏忛噰璐壒娆$敓鎴� + //鍓╀笅涓嶈冻鏃舵寜鏈�灏忛噰璐壒娆$敓鎴� + //else if (i == _DayPlanPpbom.Count && NeedQty > 0) + //{ + // NeedQty = FMINPOQTY; + // List<PurchaseInventory> _PurchaseInventory = PurchaseInventory.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId && x.FQTY > 0).ToList(); + // if (_PurchaseInventory.Count == 0) + // { + // NeedQty = 0; + // break; + // } + + // foreach (var Purchase in _PurchaseInventory) + // { + // if (Purchase.FQTY >= NeedQty) + // { + + // List<int> mmm = new List<int>(); + // foreach (int id in FEntryIdList) + // { + // mmm.Add(id); + // var DayPlanPpbomls = DayPlanPpbom.Where(c => c.FENTRYID == id && c.FMATERIALID == _item.FMATERIALID).FirstOrDefault(); + // PODemandPlanTemp.Add(new Demo.Model.Model.PODemandPlan.PODemandPlanTemp + // { + // FID = DayPlanPpbomls.FID, + // FHMASTERDATE = DATE, + // FQty = DayPlanPpbomls.NeedQty, + // FBILLNO = DayPlanPpbomls.FBILLNO, + // FENTRYID = DayPlanPpbomls.FENTRYID, + // FMATERIALID = DayPlanPpbomls.FMATERIALID, + // FNumber = DayPlanPpbomls.FNumber, + // OLDDATE = DayPlanPpbomls.FHMASTERDATE, + // FFIXLEADTIME = FFIXLEADTIME, + + // PurchseFID = Purchase.FID, + // PurchseFentryID = Purchase.FENTRYID, + // FSUPPLIERID = Purchase.FSUPPLIERID, + // PurchseFNUMBER = Purchase.FNUMBER, + // PurchseFBillNo = Purchase.FBillNo, + // PurchseFqty = Purchase.FQTY + + // }); + // //鎵i櫎鏃ヨ鍒掓槑缁嗗凡琚垎閰嶇殑鏁伴噺 + // DayPlanPpbomls.NeedQty = 0; + // } + // FEntryIdList.Clear(); + // //鏇存柊閲囪喘璁㈠崟 + // sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount =isnull(FPODemandPlanCount,0)+ '{NeedQty}' where FENTRYID = {Purchase.FENTRYID}"); + // //鎵i櫎褰撳墠琛屽搴旈噰璐鍗曟暟閲� + // var ls = PurchaseInventory.Where(c => c.FENTRYID == Purchase.FENTRYID).FirstOrDefault(); + // ls.FQTY -= NeedQty; + // break; + // } + // else + // { + // NeedQty = NeedQty - Purchase.FQTY; + // decimal _NeedQty = Purchase.FQTY;//閲囪喘璁㈠崟鏁伴噺 + // List<int> mmm = new List<int>(); + // foreach (int id in FEntryIdList) + // { + + // var DayPlanPpbomls = DayPlanPpbom.Where(c => c.FENTRYID == id && c.FMATERIALID == _item.FMATERIALID).FirstOrDefault(); + // decimal Qty = DayPlanPpbomls.NeedQty; + // if (Qty > _NeedQty) + // Qty = _NeedQty; + // _NeedQty = _NeedQty - DayPlanPpbomls.NeedQty; + // PODemandPlanTemp.Add(new Demo.Model.Model.PODemandPlan.PODemandPlanTemp + // { + // FID = DayPlanPpbomls.FID, + // FHMASTERDATE = DATE, + // FQty = Qty, + // FBILLNO = DayPlanPpbomls.FBILLNO, + // FENTRYID = DayPlanPpbomls.FENTRYID, + // FMATERIALID = DayPlanPpbomls.FMATERIALID, + // FNumber = DayPlanPpbomls.FNumber, + // OLDDATE = DayPlanPpbomls.FHMASTERDATE, + // FFIXLEADTIME = FFIXLEADTIME, + + + // PurchseFID = Purchase.FID, + // PurchseFentryID = Purchase.FENTRYID, + // FSUPPLIERID = Purchase.FSUPPLIERID, + // PurchseFNUMBER = Purchase.FNUMBER, + // PurchseFBillNo = Purchase.FBillNo, + // PurchseFqty = Purchase.FQTY + + + // }); + // DayPlanPpbomls.NeedQty -= Qty; + // //鏇存柊閲囪喘璁㈠崟 + // sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount = isnull(FPODemandPlanCount,0)+ '{Qty}' where FENTRYID = {Purchase.FENTRYID}"); + + // //鏇存柊Model + // var ls = PurchaseInventory.Where(c => c.FENTRYID == Purchase.FENTRYID).FirstOrDefault(); + // ls.FQTY -= Qty; + + // if (_NeedQty < 0) + // { + // foreach (var mm in mmm) + // { + // FEntryIdList.Remove(mm); + // } + // break; + // } + + // mmm.Add(id); + // } + // foreach (var mm in mmm) + // { + // FEntryIdList.Remove(mm); + // } + + // } + // } + // NeedQty = 0; + //} + #endregion + i++; + } + } + + var PODemandPlanList222 = PODemandPlanTemp.GroupBy(p => new PODemandPlanTemp { PurchseFNUMBER = p.PurchseFNUMBER, FHMASTERDATE = p.FHMASTERDATE }).Select(x => new PODemandPlanTemp { PurchseFNUMBER = x.Key.PurchseFNUMBER, FHMASTERDATE = x.Key.FHMASTERDATE }).ToList(); + + var PODemandPlanList = PODemandPlanTemp.GroupBy(p => new { p.PurchseFNUMBER, p.FHMASTERDATE }).Select(x => new PODemandPlanTemp { PurchseFNUMBER = x.Key.PurchseFNUMBER, FHMASTERDATE = x.Key.FHMASTERDATE }).ToList(); + + + foreach (var item in PODemandPlanList) + { + DateTime date = item.FHMASTERDATE; + string PurchseFNUMBER = item.PurchseFNUMBER; + + JObject model = new JObject(); + model.Add("FHDate", date); + model.Add("FHRemark", "鐢熶骇璁㈠崟鍙凤細" + "娴嬭瘯鍛㈠憿"); + model.Add("FSupplierID", new JObject() { ["Fnumber"] = PurchseFNUMBER }); + JArray Fentity = new JArray(); + + List<PODemandPlanTemp> _PODemandPlanList = PODemandPlanTemp.Where(x => x.FHMASTERDATE == date && x.PurchseFNUMBER == PurchseFNUMBER).ToList(); + foreach (var _item in _PODemandPlanList) + { + JObject FentityModel = new JObject(); + + FentityModel.Add("FHPURCHASEORGID", new JObject() { ["Fnumber"] = _item.FORGNumber });//閲囪喘缁勭粐 + + FentityModel.Add("FHMaterID", new JObject() { ["Fnumber"] = _item.FNumber });//鐗╂枡 + FentityModel.Add("FHQty", _item.FQty);//鏁伴噺 + FentityModel.Add("FHSourceInterID", _item.FID);//鏃ヨ鍒掑伐鍗旻ID + FentityModel.Add("FHSourceEntryID", _item.FENTRYID);//鏃ヨ鍒掑伐鍗旻ENTRYID + FentityModel.Add("FHSourceBillNo", _item.FBILLNO);//鏃ヨ鍒掑伐鍗曞崟鍙� + FentityModel.Add("FHSourceBillType", "");//鏃ヨ鍒掑伐鍗曠被鍨� + FentityModel.Add("FDayPlanDate", _item.OLDDATE);//鏃ヨ鍒掑伐鍗曠被鍨� + FentityModel.Add("FHRelationQty", _item.PurchseFqty);//鍏宠仈鏁伴噺 + FentityModel.Add("FFIXLEADTIME", _item.FFIXLEADTIME);//鎻愬墠鏈� + FentityModel.Add("FPURCHASEORGID", new JObject() { ["Fnumber"] = _item.FORGNumber });//閲囪喘缁勭粐 + FentityModel.Add("FHPOOrderInterID", _item.PurchseFID);// 閲囪喘璁㈠崟鍐呯爜锛欶HPOOrderInterID + FentityModel.Add("FHPOOrderEntryID", _item.PurchseFentryID); //閲囪喘璁㈠崟瀛愬唴鐮侊細FHPOOrderEntryID + FentityModel.Add("FHPOOrderBillNo", _item.PurchseFBillNo); //閲囪喘璁㈠崟鍙凤細FHPOOrderBillNo + Fentity.Add(FentityModel); + } + model.Add("FEntity", Fentity); + JObject jsonRoot = new JObject() + { + ["Creator"] = "", + ["NeedUpDateFields"] = new JArray(), + ["NeedReturnFields"] = new JArray(), + ["IsDeleteEntry"] = "false", + ["SubSystemId"] = "", + ["IsVerifyBaseDataField"] = "false", + ["Model"] = model + }; + CloudClient cloudClient = new CloudClient("http://localhost/K3Cloud/"); + var result = cloudClient.Save("paez_PODemandPlan", jsonRoot.ToString()); + JObject saveObj = JObject.Parse(result); + string saveIsSuc = saveObj["Result"]["ResponseStatus"]["IsSuccess"].ToString().ToUpper(); + + LogHelper.Info("鏈�鍚�"); + LogHelper.Info(jsonRoot.ToString()); + if (saveIsSuc == "TRUE") + { + } + else + { + LogHelper.Error(saveIsSuc); + + } + } + DBServiceHelper.ExecuteBatch(Context, sqlList); + // var PODemandPlanList22 = PODemandPlanTemp.GroupBy(p => new {p.FSUPPLIERID, p.FHMASTERDATE }).ToList(); + } + /// <summary> + /// 1.閿佸簱锛屽叿浣撳瓧娈垫牴鎹笟鍔″崟鎹喅瀹氾紝鈥業nv鈥欒〃绀哄嵆鏃跺簱瀛橈紝鈥楩InvDetailID鈥欎负鍗虫椂搴撳瓨ID + /// </summary> + public void Reserve() + { + try + { + decimal ReserveCount = Convert.ToDecimal((this.Model.GetValue("FReservedCount"))); + if (ReserveCount == 0) + { + this.View.ShowMessage("璇疯緭鍏ラ鐣欐暟閲�"); + return; + } + //鑾峰彇鍗曟嵁浣撲俊鎭� + Entity entity = this.View.BillBusinessInfo.GetEntity("FEntity"); + //鍗曟嵁浣撲俊鎭浆鎹负鍒楄〃闆嗗悎 + DynamicObjectCollection entityDataObjoct = this.View.Model.GetEntityDataObject(entity); + EntryGrid grid = this.View.GetControl<EntryGrid>("FEntity"); + //鎬诲簱瀛� 鐗╂枡+搴撳瓨缁勭粐+搴撳瓨鏁伴噺 + DataSet ds = DBServiceHelper.ExecuteDataSet(Context, @" +/*dialect*/ + select sum(isnull(a.FBASEQTY,0)-ISNULL(b.FHUseQty,0))FBASEQTY,T1.FStockOrgId,T1.FMATERIALID from +( +select a.FHPRDORGID FStockOrgId,T2.FMATERIALID from SC_WORKBILLSORTBILLMAIN a +join SC_WORKBILLSORTBILLSub b on a.FID = b.FID +join T_PRD_PPBOM T1 on a.FPRDMOMAINID = t1.FMoId and a.FPRDMOENTYID = t1.FMOENTRYID +LEFT JOIN(select FID,FMATERIALID from T_PRD_PPBOMENTRY +group by FMATERIALID,FID) T2 on T1.FID = t2.FID +group by a.FHPRDORGID,T2.FMATERIALID +) T1 +LEFT JOIN T_STK_Inventory a on T1.FStockOrgId = a.FStockOrgId and T1.FMATERIALID =a.FMATERIALID +LEFT JOIN JIT_MOMaterReadysBill B ON T1.FStockOrgId = b.FHSTOCKORGID and T1.FMATERIALID =b.FHMATERID +--where T1.FMATERIALID in (105773) +group by T1.FStockOrgId,T1.FMATERIALID +"); + ListInventoryByStockOrgId = ds.ToModelList<PRD_Inventory>(); + foreach (DynamicObject current in entityDataObjoct) + { + if (Convert.ToString(current["FFOCUS"]) == "False") + continue; + string sql = string.Format(@" +/*dialect*/ +--鐢熶骇鐢ㄦ枡娓呭崟鍒楄〃 +SELECT T1.FID,T1.FBillNo,T1.FMOBillNO,T1.FMOEntrySeq,T1.FMoId,T1.FMaterialID,T1.FQty,FPRDORGID FStockOrgId, +T2.FMATERIALID FMATERIALID2,T4.FNumber,T2.FNeedQty,convert(decimal(18,2),FNeedQty/FQty ) as dwyl +--,isnull(t3.FBASEQTY,0)FBASEQTY + FROM T_PRD_PPBOM T1 +LEFT JOIN (select FID,MAX(FENTRYID)FENTRYID,SUM(FNeedQty)FNeedQty,FMATERIALID from T_PRD_PPBOMENTRY where FMoId='{0}' +group by FMATERIALID,FID ) T2 on T1.FID=t2.FID +--LEFT JOIN T_STK_Inventory T3 on t2.FMATERIALID = t3.FMATERIALID +LEFT JOIN T_BD_MATERIAL T4 on T2.FMATERIALID=T4.FMATERIALID +where t1.FMoId='{0}' and T1.FMaterialID='{1}' +", current["FHMainSourceInterID"].ToString(), current["FMatrailId_Id"].ToString()); + ds = DBServiceHelper.ExecuteDataSet(Context, sql); + var PpbomList = ds.ToModelList<PRD_PPBOM>(); + //褰撳墠鏈�澶ч綈濂楁暟 涓嬪眰闇�姹傛暟閲�/鐖剁骇闇�姹傛暟閲�=鍗曚綅鐢ㄦ枡 + //var SumGetComplete = Math.Floor(PpbomList.Min(t => t.FBASEQTY / (t.FNeedQty / t.FQty))); + //鏈�澶ч綈濂楁暟 + var result = (from a in PpbomList + join b in ListInventoryByStockOrgId + on new { materialId = a.FMATERIALID2, stockOrgId = a.FStockOrgId } + equals new { materialId = b.FMATERIALID, stockOrgId = b.FStockOrgId } + into g + from b in g.DefaultIfEmpty() + select new + { + value = (b?.FBASEQTY / a.dwyl) ?? 0 + }).ToList().Min(x => x.value); + if (result < ReserveCount) + { + this.View.ShowErrMessage("褰撳墠搴撳瓨瓒呭嚭鍙鐣欐渶澶ф暟锛�" + result + ""); + return; + }; + //灏嗛鐣欐暟閲忓垎閰嶅埌鏃ヨ鍒掑伐鍗� + sql = string.Format(@"/*dialect*/select FEntryID,FHQTY from Sc_WorkBillSortBillSub +where FID='{0}' and isnull(FCOMPLETE,'鏈綈濂�')='鏈綈濂�'", current["FDayPlanWorkID"].ToString()); + DataTable dayPlanDt = DBServiceHelper.ExecuteDataSet(Context, sql).Tables[0]; + var count = ReserveCount; + List<string> sqlList = new List<string>(); + if (dayPlanDt.Rows.Count > 0) + { + foreach (DataRow dr in dayPlanDt.Rows) + { + if (count > 0) + { + sql = string.Format("/*dialect*/ update Sc_WorkBillSortBillSub set FReservedCount = {0} where FEntryID = {1}", count >= Convert.ToDecimal(dr["FHQTY"]) ? Convert.ToDecimal(dr["FHQTY"]) : count, dr["FEntryID"].ToString()); + sqlList.Add(sql); + count = count - Convert.ToDecimal(dr["FHQTY"]); + } + else + break; + } + DBServiceHelper.ExecuteBatch(Context, sqlList); + } + sql = string.Format(@"/*dialect*/ +--鐢熶骇鐢ㄦ枡娓呭崟鍒楄〃 +SELECT T1.FID,T1.FBillNo,T1.FMOBillNO,T1.FMOEntrySeq,T1.FMoId,T1.FMaterialID,T1.FQty,FPRDORGID FStockOrgId, +T2.FMATERIALID FMATERIALID2,T4.FNumber,T2.FNeedQty,convert(decimal(18,2),FNeedQty/T1.FQty ) as dwyl, +t5.FBASEUNITID,t6.FSTOREUNITID,t7.FID FSTKID,t7.FOwnerID,t7.FOwnerTypeID,t7.FSTOCKID,t7.FBASEQTY +--,isnull(t3.FBASEQTY,0)FBASEQTY + FROM T_PRD_PPBOM T1 +LEFT JOIN (select FID,MAX(FENTRYID)FENTRYID,SUM(FNeedQty)FNeedQty,FMATERIALID from T_PRD_PPBOMENTRY where FMoId='{0}' +group by FMATERIALID,FID ) T2 on T1.FID=t2.FID +--LEFT JOIN T_STK_Inventory T3 on t2.FMATERIALID = t3.FMATERIALID +LEFT JOIN T_BD_MATERIAL T4 on T2.FMATERIALID=T4.FMATERIALID +join t_BD_MaterialBase t5 on t4.FMATERIALID = t5.FMATERIALID +join t_BD_MaterialStock t6 on t4.FMATERIALID = t6.FMATERIALID +join T_STK_INVENTORY t7 on t4.FMATERIALID = t7.FMATERIALID and t1.FPRDORGID=t7.FSTOCKORGID +where t1.FMoId='{0}' and T1.FMaterialID='{1}' +", current["FHMainSourceInterID"].ToString(), current["FMatrailId_Id"].ToString()); + DataTable skDt = DBServiceHelper.ExecuteDataSet(Context, sql).Tables[0]; + //閿佸簱 + List<LockStockArgs> list = new List<LockStockArgs>(); + foreach (DataRow dr in skDt.Rows) + { + LockStockArgs lockStockArgs = new LockStockArgs(); + lockStockArgs.ObjectId = "SAL_SaleOrder"; + lockStockArgs.BillId = Convert.ToString(current["FHMainSourceInterID"]); //鐢熶骇璁㈠崟ID + lockStockArgs.BillNo = Convert.ToString(current["FSCOrderNo"]);//鐢熶骇璁㈠崟鍙� + lockStockArgs.FID = Convert.ToInt32(current["FHMainSourceInterID"]); //鐢熶骇璁㈠崟ID + lockStockArgs.BaseQty = decimal.Parse(dr["FBASEQTY"].ToString());//鍩烘湰鍗曚綅鏁伴噺 + lockStockArgs.BaseUnitID = int.Parse(dr["FBASEUNITID"].ToString());//鍩烘湰鍗曚綅 + lockStockArgs.BillDetailID = Convert.ToString(current["FHMainSourceEntryID"]); + lockStockArgs.FEntryID = Convert.ToInt32(current["FHMainSourceEntryID"]); ; + //lockStockArgs.Lot = Convert.ToString(current["FBatch"]); ;//鎵规 FBatch + lockStockArgs.MaterialID = long.Parse(dr["FMATERIALID2"].ToString()); + lockStockArgs.OwnerID = long.Parse(dr["FOwnerID"].ToString()); + lockStockArgs.OwnerTypeID = dr["FOwnerTypeID"].ToString(); + lockStockArgs.Qty = Convert.ToDecimal(dr["dwyl"].ToString()) * ReserveCount;//鏁伴噺 + lockStockArgs.STOCKID = long.Parse(dr["FSTOCKID"].ToString());//浠撳簱 + lockStockArgs.StockOrgID = long.Parse(dr["FStockOrgId"].ToString());//搴撳瓨缁勭粐 + lockStockArgs.UnitID = long.Parse(dr["FSTOREUNITID"].ToString());//鍗曚綅 + lockStockArgs.LockBaseQty = Convert.ToDecimal(dr["dwyl"].ToString()) * ReserveCount; + lockStockArgs.LockQty = Convert.ToDecimal(dr["dwyl"].ToString()) * ReserveCount;//鍩烘湰鍗曚綅鏁伴噺 + lockStockArgs.FInvDetailID = Convert.ToString(dr["FSTKID"].ToString()); + list.Add(lockStockArgs); + } + var sa = StockServiceHelper.SaveLockInfo(Context, list, "Inv", false); + this.View.ShowMessage("鎿嶄綔鎴愬姛锛�"); + } + } + catch (Exception ex) + { + LogHelper.Error(ex.Message.ToString()); + this.View.ShowErrMessage(ex.Message.ToString()); + } + } + /// <summary> + /// 閲婃斁 + /// </summary> + public void Release() + { + try + { + //鑾峰彇鍗曟嵁浣撲俊鎭� + Entity entity = this.View.BillBusinessInfo.GetEntity("FEntity"); + //鍗曟嵁浣撲俊鎭浆鎹负鍒楄〃闆嗗悎 + DynamicObjectCollection entityDataObjoct = this.View.Model.GetEntityDataObject(entity); + DynamicObjectCollection filterResult = entityDataObjoct.Clone(); + filterResult.Clear(); + entityDataObjoct.Where(x => Convert.ToBoolean(x["FFOCUS"])).ToList().ForEach(x=> filterResult.Add(x)); + foreach (DynamicObject current in entityDataObjoct) + { + if (Convert.ToString(current["FFOCUS"]) == "False") + continue; + string sql = string.Format(@"/*dialect*/ update Sc_WorkBillSortBillSub set FReservedCount = 0 where FID='{0}'", current["FDayPlanWorkID"].ToString()); + DBServiceHelper.Execute(Context, sql); + } + this.View.ShowMessage("鎿嶄綔鎴愬姛锛�"); + } + catch (Exception ex) + { + LogHelper.Error(ex.Message.ToString()); + this.View.ShowErrMessage(ex.Message.ToString()); + } + } } } +//tbReleaseReserve \ No newline at end of file -- Gitblit v1.9.1