From 2d3fc93b131c7aa771e8f7d08a82d5e9b4946eff Mon Sep 17 00:00:00 2001 From: yangle <admin@YINMOU> Date: 星期四, 29 六月 2023 16:02:39 +0800 Subject: [PATCH] 提料计划运算(缺料) 日志添加自定义名称方法 --- WebAPI/Controllers/SCGL/日计划管理/JIT_DayPlanPlatFormBillController.cs | 2485 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 2,482 insertions(+), 3 deletions(-) diff --git "a/WebAPI/Controllers/SCGL/\346\227\245\350\256\241\345\210\222\347\256\241\347\220\206/JIT_DayPlanPlatFormBillController.cs" "b/WebAPI/Controllers/SCGL/\346\227\245\350\256\241\345\210\222\347\256\241\347\220\206/JIT_DayPlanPlatFormBillController.cs" index 49ffe62..70089ce 100644 --- "a/WebAPI/Controllers/SCGL/\346\227\245\350\256\241\345\210\222\347\256\241\347\220\206/JIT_DayPlanPlatFormBillController.cs" +++ "b/WebAPI/Controllers/SCGL/\346\227\245\350\256\241\345\210\222\347\256\241\347\220\206/JIT_DayPlanPlatFormBillController.cs" @@ -6,21 +6,26 @@ using System.Web.Http; using WebAPI.Models; using Newtonsoft.Json; +using Newtonsoft.Json.Linq; +using System.Diagnostics; namespace WebAPI.Controllers.SCGL.鏃ヨ鍒掔鐞� { public class JIT_DayPlanPlatFormBillController : ApiController { + List<PRD_Inventory> ListInventory;//搴撳瓨鏄庣粏 private json objJsonResult = new json(); public DataSet ds = new DataSet(); public WebServer webserver = new WebServer(); SQLHelper.ClsCN oCN = new SQLHelper.ClsCN(); Sc_WorkBillSortBillMain omdelMian = new Sc_WorkBillSortBillMain(); + public static string BillType = "4610"; + Pub_Class.ClsXt_SystemParameter oSystemParameter = new Pub_Class.ClsXt_SystemParameter(); #region 鐢熶骇鏃ヨ鍒掑钩鍙� 鏌ヨ [Route("JIT_DayPlanPlatFormBill/JIT_DayPlanPlatFormBillList")] [HttpGet] - public object JIT_DayPlanPlatFormBillList(string sWhere,string user) + public object JIT_DayPlanPlatFormBillList(string sWhere, string user) { try { @@ -36,8 +41,45 @@ omdelMian = JsonConvert.DeserializeObject<Sc_WorkBillSortBillMain>(sWhere); - ds = oCN.RunProcReturn($"exec h_p_JIT_Sc_WorkBillSortBill_Query '{omdelMian.HPlanBeginDate}',{(omdelMian.HProdORGID==null?0: omdelMian.HProdORGID)},'{omdelMian.HSeOrderBillNo}'" + - $",'{omdelMian.HPlanEndDate}',{omdelMian.HMaterID},'{omdelMian.HICMOBillNo}',{omdelMian.HWorkShopID}", "h_p_JIT_Sc_WorkBillSortBill_Query"); + ds = oCN.RunProcReturn($"exec h_p_JIT_Sc_WorkBillSortBill_Query '{omdelMian.HPlanBeginDate}',{(omdelMian.HProdORGID == null ? 0 : omdelMian.HProdORGID)},'{omdelMian.HSeOrderBillNo}'" + + $",'{omdelMian.HPlanEndDate.AddDays(1)}',{omdelMian.HMaterID},'{omdelMian.HICMOBillNo}',{omdelMian.HWorkShopID}", "h_p_JIT_Sc_WorkBillSortBill_Query"); + + objJsonResult.code = "1"; + objJsonResult.count = 1; + objJsonResult.Message = "Sucess锛�"; + objJsonResult.data = ds.Tables[0]; + return objJsonResult; + } + catch (Exception e) + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "Exception锛�" + e.ToString(); + objJsonResult.data = null; + return objJsonResult; + } + } + + /// <summary> + /// 鏍规嵁ID鏌ヨ 榻愬鐘舵�� 鍜� 閿佸畾鐘舵�� + /// </summary> + /// <param name="sWhere"></param> + /// <param name="user"></param> + /// <returns></returns> + [Route("JIT_DayPlanPlatFormBill/JIT_DayPlanPlatFormBillHinterIDList")] + [HttpGet] + public object JIT_DayPlanPlatFormBillHinterIDList(string sWhere,int num) + { + try + { + if (num == 1) + { + ds = oCN.RunProcReturn($"select isnull(DATEDIFF(DAY,GETDATE(),CONVERT(varchar(10),max(HMasterDate),20))+1,0) DayNum from Sc_WorkBillSortBillSub where HInterID in ({sWhere}) and HMasterDate>=CONVERT(varchar(10),GETDATE(),20) and HLockedSub=1", "Sc_WorkBillSortBillSub"); + } + else if (num == 2) + { + ds = oCN.RunProcReturn($"select CONVERT(varchar(10),HMasterDate,20) HMasterDate,HComplete,HInterID from Sc_WorkBillSortBillSub where HInterID in ({sWhere}) and HMasterDate>=CONVERT(varchar(10),GETDATE(),20) and (HComplete='榻愬' or HComplete='鏈綈濂�') ", "Sc_WorkBillSortBillSub"); + } objJsonResult.code = "1"; objJsonResult.count = 1; @@ -55,5 +97,2442 @@ } } #endregion + + #region 鐢熶骇鏃ヨ鍒掑钩鍙� 淇濆瓨 + [Route("JIT_DayPlanPlatFormBill/JIT_DayPlanPlatFormBill_btnSave")] + [HttpPost] + public object JIT_DayPlanPlatFormBill_btnSave([FromBody] JObject sMainSub) + { + var _value = sMainSub["sMainSub"].ToString(); + string msg1 = _value.ToString(); + oCN.BeginTran(); + //淇濆瓨涓昏〃 + objJsonResult = AddBillMain(msg1); + if (objJsonResult.code == "0") + { + oCN.RollBack(); + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = objJsonResult.Message; + objJsonResult.data = null; + return objJsonResult; + } + oCN.Commit(); + objJsonResult.code = "1"; + objJsonResult.count = 1; + objJsonResult.Message = "鍗曟嵁淇濆瓨鎴愬姛锛�"; + objJsonResult.data = null; + return objJsonResult; + } + + public json AddBillMain(string msg1) + { + string[] sArray = msg1.Split(new string[] { ";" }, StringSplitOptions.RemoveEmptyEntries); + string msg2 = sArray[0].ToString(); + string user = sArray[1].ToString(); + + try + { + if (!DBUtility.ClsPub.Security_Log("Sc_WorkBillSortBill_Edit", 1, false, user)) + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "鏃犱繚瀛樻潈闄愶紒"; + objJsonResult.data = null; + return objJsonResult; + } + + //JSON搴忓垪鍖栬浆鎹㈠瓧鍏搁泦鍚� + List<Dictionary<string, string>> list = new List<Dictionary<string, string>>(); + List<object> jb = JsonConvert.DeserializeObject<List<object>>(msg2); + foreach (JObject item in jb) + { + Dictionary<string, string> dic = new Dictionary<string, string>(); + foreach (var itm in item.Properties()) + { + dic.Add(itm.Name, itm.Value.ToString()); + } + list.Add(dic); + } + + int TrueCount = 0, SumCount = 0; + + for (int i = 0; i < list.Count; i++) + { + TrueCount = 0; + SumCount = 0; + long HInterID = 0; + var HBillNo = ""; + if (list[i]["鍗曟嵁鍙�"].ToString() == "" && list[i]["hmainid"].ToString() == "") + { + var HICMOBillNo = list[i]["鐢熶骇璁㈠崟鍙�"].ToString(); + var HOrderType = list[i]["璁㈠崟绫诲瀷"].ToString(); + var HICMOEntrySEQ = list[i]["鐢熶骇璁㈠崟鏄庣粏琛屽彿"].ToString(); + var HWorkShopID = list[i]["HWorkShopID"].ToString(); + var HSourceID = list[i]["HSourceID"].ToString(); + var HYX = list[i]["浼樺厛绾�"].ToString(); + var HProdORGID = list[i]["HProdORGID"].ToString(); + var HMaterID = list[i]["HMaterID"].ToString(); + var HMaterName = list[i]["鐗╂枡鍚嶇О"].ToString(); + var HMaterModel = list[i]["瑙勬牸鍨嬪彿"].ToString(); + var HUnitID = list[i]["HUnitID"].ToString(); + var HSeOrderBillQty = list[i]["閿�鍞鍗曟暟閲�"].ToString(); + //var HOrderNeedQty = list[i]["璁㈠崟闇�姹傛暟閲�"].ToString(); + var HSplitQty = list[i]["鎷嗗崟鏁伴噺"].ToString(); + var HDayPlanSumQty = list[i]["鏃ヨ鍒掓暟閲忔�婚噺"].ToString(); + var HPlanBeginDate = list[i]["璁″垝寮�濮嬫棩鏈�"].ToString(); + var HSeOrderBillNo = list[i]["閿�鍞鍗曞彿"].ToString(); + var HICMOBillType = list[i]["鐢熶骇璁㈠崟鍗曟嵁绫诲瀷"].ToString(); + var HSourceStockInQty = list[i]["浜х嚎鍏ュ簱鏁伴噺"].ToString(); + var HLeftPlanQty = list[i]["鏈帓鏁伴噺"].ToString(); + var HOrderLev = list[i]["璁㈠崟绛夌骇"].ToString(); + var HMainSourceInterID = list[i]["婧愬崟涓诲唴鐮�"].ToString(); + var HMainSourceEntryID = list[i]["婧愬崟瀛愬唴鐮�"].ToString(); + var HPlanQty = list[i]["璁″垝鏁伴噺"].ToString(); + + if (HSourceID == ""|| HSourceID == "0") + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = $"绗瑊i + 1}琛岀敓浜ц祫婧愪笉鑳戒负绌�!"; + objJsonResult.data = null; + return objJsonResult; + } + + ds = oCN.RunProcReturn($"select * from Sc_WorkBillSortBillMain where HMainSourceInterID={HMainSourceInterID}" + + $" and HMainSourceEntryID={HMainSourceEntryID} and HICMOBillNo='{HICMOBillNo}' and HICMOEntrySEQ={HICMOEntrySEQ} and HSourceID={HSourceID}", "Sc_WorkBillSortBillMain"); + if (ds.Tables[0].Rows.Count > 0) + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = $"绗瑊i + 1}琛岀敓浜ц祫婧愭湁閲嶅,璇蜂慨鏀�!"; + objJsonResult.data = null; + return objJsonResult; + } + + //鏂板鍗曟嵁鍙� id + HBillNo = DBUtility.ClsPub.CreateBillCode_Prod(BillType, ref DBUtility.ClsPub.sExeReturnInfo, true);//鑾峰緱涓�涓柊鐨勫崟鎹彿 + HInterID = DBUtility.ClsPub.CreateBillID_Prod(BillType, ref DBUtility.ClsPub.sExeReturnInfo);//鑾峰緱涓�涓柊鐨刬d + + string sql = $"insert into Sc_WorkBillSortBillMain(HInterID,HBillNo,HYear,HPeriod,HBillType," + + "HBillSubType,HDate,HBillStatus,HMaker,HMakeDate,HICMOBillNo,HOrderType," + + "HICMOEntrySEQ,HWorkShopID,HSourceID, HYX, HProdORGID," + + " HMaterID, HMaterName, HMaterModel, HUnitID, HSeOrderBillQty," + + " HOrderNeedQty, HSplitQty, HDayPlanSumQty,HPlanBeginDate," + + "HSeOrderBillNo,HICMOBillType,HSourceStockInQty,HLeftPlanQty,HOrderLev,HPreparatDate," + + "HMainSourceInterID,HMainSourceEntryID,HICMOInterID_Sec,HICMOEntryID_Sec,HPlanQty)values" + + $"({HInterID},'{HBillNo}',{DateTime.Now.Year},{DateTime.Now.Month},'{BillType}'," + + $"'{BillType}',GETDATE(),1,'{user}',getdate(),'{HICMOBillNo}','{HOrderType}'," + + $"{(HICMOEntrySEQ == "" ? 0.ToString() : HICMOEntrySEQ)},{(HWorkShopID == "" ? 0.ToString() : HWorkShopID)},{(HSourceID == "" ? 0.ToString() : HSourceID)}, {(HYX == "" ? 0.ToString() : HYX)}, {(HProdORGID == "" ? 0.ToString() : HProdORGID)}," + + $" {(HMaterID == "" ? 0.ToString() : HMaterID)}, '{HMaterName}', '{HMaterModel}', {(HUnitID == "" ? 0.ToString() : HUnitID)}, {(HSeOrderBillQty == "" ? 0.ToString() : HSeOrderBillQty)}," + + $" 0, {(HSplitQty == "" ? 0.ToString() : HSplitQty)}, {(HDayPlanSumQty == "" ? 0.ToString() : HDayPlanSumQty)},'{HPlanBeginDate}'," + + $"'{HSeOrderBillNo}','{HICMOBillType}',{(HSourceStockInQty == "" ? 0.ToString() : HSourceStockInQty)},{(HLeftPlanQty == "" ? 0.ToString() : HLeftPlanQty)},'{HOrderLev}',getdate()," + + $"{HMainSourceInterID},{HMainSourceEntryID},{HMainSourceInterID},{HMainSourceEntryID},{HPlanQty})"; + + //LogService.Write("sql:" + sql); + //涓昏〃 + oCN.RunProc(sql); + } + else + { + var HMainSourceInterID = list[i]["婧愬崟涓诲唴鐮�"].ToString(); + var HMainSourceEntryID = list[i]["婧愬崟瀛愬唴鐮�"].ToString(); + var HICMOBillNo = list[i]["鐢熶骇璁㈠崟鍙�"].ToString(); + var HICMOEntrySEQ = list[i]["鐢熶骇璁㈠崟鏄庣粏琛屽彿"].ToString(); + var HSourceID = list[i]["HSourceID"].ToString(); + var HYX = list[i]["浼樺厛绾�"].ToString(); + + if (HSourceID == "" || HSourceID == "0") + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = $"绗瑊i + 1}琛岀敓浜ц祫婧愪笉鑳戒负绌�!"; + objJsonResult.data = null; + return objJsonResult; + } + var str = 0; + if (!int.TryParse(HYX, out str)) + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = $"绗瑊i + 1}琛屼紭鍏堢骇:{HYX},璇疯緭鍏ユ暟瀛�!"; + objJsonResult.data = null; + return objJsonResult; + } + + ds = oCN.RunProcReturn($"select * from Sc_WorkBillSortBillMain where HMainSourceInterID={HMainSourceInterID}" + + $" and HMainSourceEntryID={HMainSourceEntryID} and HICMOBillNo='{HICMOBillNo}' and HICMOEntrySEQ={HICMOEntrySEQ} and HSourceID={HSourceID}", "Sc_WorkBillSortBillMain"); + + if (ds.Tables[0].Rows.Count > 1) + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = $"绗瑊i + 1}琛岀敓浜ц祫婧愭湁閲嶅,璇蜂慨鏀�!"; + objJsonResult.data = null; + return objJsonResult; + } + + oCN.RunProc($"update Sc_WorkBillSortBillMain set HSourceID={(HSourceID == "" ? 0.ToString() : HSourceID)},HYX={HYX} where HInterID={list[i]["hmainid"].ToString()} and HBillNo='{list[i]["鍗曟嵁鍙�"].ToString()}'"); + } + + oCN.RunProc($"update Sc_WorkBillSortBillMain set HDayPlanSumQty={list[i]["鏃ヨ鍒掓暟閲忔�婚噺"].ToString()} where HInterID={(HInterID==0?int.Parse(list[i]["hmainid"].ToString()):HInterID)} and HBillNo='{(HBillNo==""?list[i]["鍗曟嵁鍙�"].ToString(): HBillNo)}'"); + + int SumDay = 31; //鍔ㄦ�佷袱鏈堜箣宸� DateTime.Now.AddMonths(1).AddDays(-1).Subtract(DateTime.Now).Days; + + for (int j = 0; j < SumDay; j++) + { + //涓昏〃瀛愯〃閮芥湁鏁版嵁 + if (list[i][DateTime.Now.AddDays(j).ToString("yyyy-MM-dd")].ToString() != "") + { + SumCount += 1; + ////淇濆瓨瀛愯〃 + objJsonResult = AddBillSub(HInterID == 0 ? list[i]["hmainid"].ToString() : HInterID.ToString() + , HBillNo == "" ? list[i]["鍗曟嵁鍙�"].ToString() : HBillNo + , DateTime.Parse(DateTime.Now.AddDays(j).ToString("yyyy-MM-dd").ToString()) + , int.Parse(list[i][DateTime.Now.AddDays(j).ToString("yyyy-MM-dd")].ToString())); + + if (objJsonResult.count == 1) + { + TrueCount += 1; + } + } + //涓昏〃鏈夋暟鎹� 瀛愯〃鏃犳暟鎹� + if (j == 30 && SumCount == 0 && HInterID != 0 && HBillNo != "") + { + objJsonResult = AddBillSub(HInterID.ToString(), HBillNo, DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd").ToString()), 0); + } + } + } + + if (TrueCount != SumCount) + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = objJsonResult.Message; + objJsonResult.data = null; + return objJsonResult; + } + + //鍚屾鏃ヨ鍒掑伐鍗� + oCN.RunProc("exec REALESE_SC_ICMOBILLSTATUS_TMP"); + + objJsonResult.code = "1"; + objJsonResult.count = 1; + objJsonResult.Message = null; + objJsonResult.data = null; + return objJsonResult; + } + catch (Exception e) + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "Exception锛�" + e.ToString(); + objJsonResult.data = null; + return objJsonResult; + } + } + + public json AddBillSub(string HInterID, string HBillNo, DateTime date, int HQTY) + { + //鑾峰彇琛ㄦ牸鏁版嵁 + ds = oCN.RunProcReturn($"select * from h_v_JIT_Sc_WorkBillSortBillList where 鍗曟嵁鍙�='{HBillNo}'", "h_v_JIT_Sc_WorkBillSortBillList"); + + int count = 0; + if (ds.Tables[0].Rows.Count > 0) + { + //鍒ゆ柇瀛愯〃鏄惁鏈夊綋鏃ョ殑鏃ユ湡浠ュ強鏃ユ湡鎵�瀵瑰簲鐨勬暟閲� + for (int i = 0; i < ds.Tables[0].Rows.Count; i++) + { + if (DateTime.Parse(ds.Tables[0].Rows[i]["鏃ヨ鍒掔敓浜ф棩鏈�"].ToString()) == date) + { + oCN.RunProc($"update Sc_WorkBillSortBillSub set HMasterDate='{date}',HQty={HQTY}" + + $" where HInterID={HInterID} and HEntryID={ds.Tables[0].Rows[i]["hsubid"].ToString()}"); + count += 1; + } + } + } + + if (count != 1) + { + //鎻掑叆瀛愯〃 + oCN.RunProc("insert into Sc_WorkBillSortBillSub(HInterID,HSEQ," + + "HMasterDate,HQty)" + + $"values({HInterID}, {(ds.Tables[0].Rows.Count + 1)}," + + $" '{date}', {HQTY})"); + } + + objJsonResult.code = "1"; + objJsonResult.count = 1; + objJsonResult.Message = null; + objJsonResult.data = null; + return objJsonResult; + } + #endregion + + #region 鐢熶骇鏃ヨ鍒掑钩鍙� 榻愬鍒嗘瀽 + + #region 娓呭崟閰嶆枡鏂瑰紡 + public class PRD_PPBOM + { + /// <summary> + /// 鏃ヨ鍒掑伐鍗曞彿 + /// </summary> + public string HMainICMOBillNo { get; set; } + /// <summary> + /// 鏃ヨ鍒掑伐鍗旻ID + /// </summary> + public long HInterID { get; set; } + /// <summary> + /// 鏃ヨ鍒掓槑缁咶EntryID + /// </summary> + public long HEntryID { get; set; } + /// <summary> + /// 鐢熶骇鐢ㄦ枡娓呭崟鍗曞彿 + /// </summary> + public string HBillNo { get; set; } + /// <summary> + /// 鐢熶骇璁㈠崟鍗曞彿 + /// </summary> + public string HICMOBillNo { get; set; } + /// <summary> + /// 鐢熶骇璁㈠崟鍐呯爜 + /// </summary> + public string HICMOInterID { get; set; } + /// <summary> + /// 鐖剁骇鐗╂枡ID + /// </summary> + public string FMaterialID { get; set; } + /// <summary> + /// 鐖剁骇鐗╂枡鏁伴噺 + /// </summary> + public decimal FQty { get; set; } + /// <summary> + /// 瀛愰」鐗╂枡ID + /// </summary> + public string FMATERIALID2 { get; set; } + /// <summary> + /// 瀛愰」鐗╂枡鍚嶇О + /// </summary> + public string FNumber { get; set; } + /// <summary> + /// 闇�姹傛暟閲� + /// </summary> + public decimal FNeedQty { get; set; } + /// <summary> + /// 鍗虫椂搴撳瓨 + /// </summary> + public decimal FBASEQTY { get; set; } + + /// <summary> + /// 鐢熶骇璁㈠崟涓荤爜 + /// </summary> + public string HICMOInterID_Sec { get; set; } + /// <summary> + /// 鐢熶骇璁㈠崟瀛愮爜 + /// </summary> + public string HICMOEntryID_Sec { get; set; } + + /// <summary> + /// 鏃ヨ鍒掓暟閲� + /// </summary> + public string HQty { get; set; } + + /// <summary> + /// 鏃ヨ鍒掓棩鏈� + /// </summary> + public DateTime HMasterDate { get; set; } + + /// <summary> + /// 璁㈠崟绛夌骇 + /// </summary> + public string HOrderLev { get; set; } + + /// <summary> + /// 搴撳瓨缁勭粐 + /// </summary> + public string FStockOrgId { get; set; } + /// <summary> + /// 缁勭粐鍚嶇О + /// </summary> + public string OrgFnumber { get; set; } + + /// <summary> + /// 鍗曚綅鐢ㄩ噺 + /// </summary> + public decimal dwyl { get; set; } + + /// <summary> + /// 棰勮娑堣�楃敤閲� + /// </summary> + public decimal PlanCount { get; set; } + /// <summary> + /// 鐗╂枡灞炴�� + /// </summary> + public int FErpClsID { get; set; } + + /// <summary> + /// 杞﹂棿 + /// </summary> + public string HWorkShopID { get; set; } + + /// <summary> + /// 杞﹂棿缂栫爜 + /// </summary> + public string FHWorkShopNumber { get; set; } + + + } + #endregion + + #region 鍗虫椂搴撳瓨 + public class PRD_Inventory + { + /// <summary> + /// 鐗╂枡ID + /// </summary> + public string FMATERIALID { get; set; } + /// <summary> + /// 鐗╂枡缂栫爜 + /// </summary> + public string FNumber { get; set; } + /// <summary> + /// 鍗虫椂搴撳瓨 + /// </summary> + public decimal FBASEQTY { get; set; } + + /// <summary> + /// 搴撳瓨缁勭粐 + /// </summary> + public string FStockOrgId { get; set; } + + /// <summary> + /// 搴撳瓨璐т富绫诲瀷 + /// </summary> + public string FOwnerTypeId { get; set; } + /// <summary> + /// 搴撳瓨璐т富 + /// </summary> + public string FOwnerId { get; set; } + + /// <summary> + /// 璐т富缂栫爜 + /// </summary> + public string FOwnerNumber { get; set; } + + /// <summary> + /// 浠撳簱 + /// </summary> + public string FSTOCKID { get; set; } + + /// <summary> + /// 浠撳簱缂栫爜 + /// </summary> + public string FStockNumber { get; set; } + /// <summary> + /// 鎵瑰彿 + /// </summary> + public string HLOT { get; set; } + /// <summary> + /// id + /// </summary> + public string HInventoryFID { get; set; } + } + #endregion + + #region 杞﹂棿浠撳簱瀵圭収鍒楄〃 + public class PRD_WorkHouseCompar + { + /// <summary> + /// 缁勭粐 + /// </summary> + public string FORGID { get; set; } + /// <summary> + /// 杞﹂棿 + /// </summary> + public string FWORKSHOPID { get; set; } + /// <summary> + /// 浠撳簱 + /// </summary> + public string FSTOCKID { get; set; } + } + #endregion + + #region 鏃ヨ鍒�+鐢熶骇璁㈠崟 + public class DayPlanPickedModel + { + /// <summary> + /// 璁㈠崟鍏ュ簱鏁伴噺 鎸夌収鐢熶骇璁㈠崟鏄庣粏琛� + /// </summary> + public decimal FCXStockInQty { get; set; } + /// <summary> + /// 涓荤敓浜ц鍗曞瓙鍐呯爜 + /// </summary> + public string FPRDMOENTYID { get; set; } + /// <summary> + /// 鐗╂枡鍗曚綅鐢ㄩ噺 + /// </summary> + public decimal dwyl { get; set; } + /// <summary> + /// 宸查鏁伴噺 + /// </summary> + public decimal FPickedQty { get; set; } + /// <summary> + /// 鍓╀綑鍙敤鏁伴噺 + /// </summary> + public decimal FRemainPickedQty { get; set; } + /// <summary> + /// 鐗╂枡 + /// </summary> + public string FMATERIALID { get; set; } + + } + #endregion + + #region 瀛樺偍涓存椂闇�瑕佹彃鍏ユ暟鎹� + public class CompleteAnalysisTempModel + { + /// <summary> + /// 涓荤敓浜ц鍗曚富鍐呯爜锛欶HMainICMOInterIDr + /// </summary> + public string FHMainICMOInterIDr { get; set; } + /// <summary> + /// 涓荤敓浜ц鍗曞瓙鍐呯爜锛欶HMainICMOEntryID + /// </summary> + public string FHMainICMOEntryID { get; set; } + /// <summary> + /// 鏃ヨ鍒掕鍗曞崟鍙凤細HMainICMOBillNo + /// </summary> + public string HMainICMOBillNo { get; set; } + /// <summary> + /// 鏃ヨ鍒掕鍗曚富鍐呯爜锛欶HICMOInterID + /// </summary> + public string FHICMOInterID { get; set; } + /// <summary> + /// 鏃ヨ鍒掕鍗曞瓙鍐呯爜锛欶HICMOEntryID + /// </summary> + public string FHICMOEntryID { get; set; } + /// <summary> + /// 瀛愪欢鐗╂枡锛欶HMaterID + /// </summary> + public string FHMaterID { get; set; } + + /// <summary> + /// 搴撳瓨缁勭粐锛欶HStockOrgID + /// </summary> + public string FHStockOrgID { get; set; } + + /// <summary> + ///鐢熶骇缁勭粐锛欶HPRDORGID + /// </summary> + public string FHPRDORGID { get; set; } + + /// <summary> + /// 鐢熶骇璁㈠崟鍙凤細FPRDBillNo + /// </summary> + public string FPRDBillNo { get; set; } + /// <summary> + /// 鏍囪瘑 + /// </summary> + public string FIdentificat { get; set; } + /// <summary> + /// 璐т富鍚嶇О锛欶OwnerName + /// </summary> + public string FOwnerName { get; set; } + /// <summary> + /// 璐т富缂栫爜锛欶OwnerId + /// </summary> + public string FOwnerId { get; set; } + /// <summary> + /// 璐т富绫诲瀷锛欶OwnerTypeId + /// </summary> + public string FOwnerTypeId { get; set; } + /// <summary> + /// 榻愬鐘舵�� + /// </summary> + public string FComPlete { get; set; } + /// <summary> + /// 鏁伴噺 + /// </summary> + public string FHUseQty { get; set; } + /// <summary> + /// 鍙婃椂搴撳瓨鏁伴噺锛欶HStockQty + /// </summary> + public decimal FHStockQty { get; set; } + /// <summary> + ///鍙敤鏁伴噺锛欶HLeftQty + /// </summary> + public decimal FHLeftQty { get; set; } + + /// <summary> + /// 缂烘枡鏁伴噺 + /// </summary> + public decimal FLackCount { get; set; } + /// <summary> + /// 鍗犵敤鏁伴噺 + /// </summary> + public decimal FOccupyCount { get; set; } + /// <summary> + /// 鍗犵敤棰嗘枡鏁伴噺 + /// </summary> + public decimal FOccupyPickedCount { get; set; } + + /// <summary> + /// 鍗曚綅鐢ㄩ噺锛欶UnitDosage + /// </summary> + public decimal FUnitDosage { get; set; } + /// <summary> + /// 璁″垝鎬绘暟閲忥細FSumPlanCount + /// </summary> + public decimal FSumPlanCount { get; set; } + /// <summary> + /// 榻愬鏁伴噺锛欶CompleteCount q + /// </summary> + public decimal FCompleteCount { get; set; } + public decimal FCompleteCount1 { get; set; } + /// <summary> + /// 鏃ヨ鍒掓棩鏈� + /// </summary> + public DateTime FPlanDate { get; set; } + //鐗╂枡绫诲瀷 + public int FErpClsID { get; set; } + //浠撳簱 + public string FStock { get; set; } + //杞﹂棿 + public string FWorkShop { get; set; } + //鎵瑰彿 + public string HLOT { get; set; } + public string HInventoryFID { get; set; } + + } + #endregion + + [Route("JIT_DayPlanPlatFormBill/JIT_CompleteSetAnalysis")] + [HttpGet] + public object JIT_CompleteSetAnalysis(string sWhere, string user) + { + try + { + Stopwatch sw = new Stopwatch(); + omdelMian = JsonConvert.DeserializeObject<Sc_WorkBillSortBillMain>(sWhere); + string sql = $"exec JIT_qtfx {omdelMian.HProdORGID},{omdelMian.HWorkShopID},'{user}' "; + ds = oCN.RunProcReturn(sql, "JIT_qtfx"); + LogService.Write("榻愬鍒嗘瀽sql:" + sql); + List<PRD_PPBOM> BomList = new List<PRD_PPBOM>(); + DataTable resulTable = ds.Tables[0]; + if (resulTable.Rows[0][0].ToString().Contains("澶辫触")) + { + //閲婃斁榻愬鎿嶄綔 閬垮厤澶氫汉鍚屾椂杩涜榻愬鍒嗘瀽 + oCN.RunProc($"update T_PRD_QTFX set FSTATUS = 0 where FPRDORGID ={omdelMian.HProdORGID} and FSTATUS = 1 "); + + objJsonResult.code = "1"; + objJsonResult.count = 1; + objJsonResult.Message = resulTable.Rows[0][0].ToString(); + objJsonResult.data = null; + return objJsonResult; + } + else + { + BomList = ds.ToModelList<PRD_PPBOM>(); + } + + string fDayPlanFids = string.Empty; + string fDayPlanFEntryids = string.Empty; + if (BomList.Count == 0) + { + //閲婃斁榻愬鎿嶄綔 閬垮厤澶氫汉鍚屾椂杩涜榻愬鍒嗘瀽 + oCN.RunProc($"update T_PRD_QTFX set FSTATUS = 0 where FPRDORGID ={omdelMian.HProdORGID} and FSTATUS = 1 "); + + objJsonResult.code = "1"; + objJsonResult.count = 1; + objJsonResult.Message = "娌℃湁闇�瑕佽繘琛岄綈濂楀垎鏋愮殑鏁版嵁"; + objJsonResult.data = null; + return objJsonResult; + } + else + { + List<string> fidList = BomList.Select(x => x.HInterID.ToString()).Distinct().ToList(); + List<string> fentryidList = BomList.Select(x => x.HEntryID.ToString()).Distinct().ToList(); + fDayPlanFids = string.Join(",", fidList); + fDayPlanFEntryids = string.Join(",", fentryidList); + } + LogService.Write("鏃ヨ鍒掑伐鍗昳ds" + fDayPlanFids); + + sw.Start();//寮�濮嬭鏃� + + //鑾峰彇褰撳墠鍗虫椂搴撳瓨 搴撳瓨鏁伴噺+搴撳瓨缁勭粐+鐗╂枡+璐т富+浠撳簱 + ds = oCN.RunProcReturn(@" +select * from h_v_jit_InventoryList +", "h_v_jit_InventoryList"); + ListInventory = ds.ToModelList<PRD_Inventory>(); + //杞﹂棿 浠撳簱瀵圭収鍒楄〃 + ds = oCN.RunProcReturn(@" +SELECT DISTINCT T1.HOrgId FORGID,HWorkShopID FWORKSHOPID,HWHID FSTOCKID FROM Gy_WorkWarehouseBillMain T1 +JOIN Gy_WorkWarehouseBillMainSub T2 ON T1.HInterID=T2.HInterID +", "Gy_WorkWarehouseBillMain"); + List<PRD_WorkHouseCompar> pRD_WorkHouseCompar = ds.ToModelList<PRD_WorkHouseCompar>(); + int i = 1;//鐢ㄤ簬杩涘害鏉$殑鍔犺浇 + //鏃ヨ鍒�+鐢熶骇璁㈠崟瀛愯〃缂栫爜ID + var DatePlanList = BomList.GroupBy(p => new { p.HMasterDate, p.HICMOEntryID_Sec }).Select(x => new PRD_PPBOM { HMasterDate = x.Key.HMasterDate, HICMOEntryID_Sec = x.Key.HICMOEntryID_Sec }).ToList(); + //鍙栧簲鍙戞暟閲� FMustQty 涓嶈鍙栧�奸渶姹傛暟閲廎NeedQty 棰嗘枡鏁版嵁 + string LLsql = string.Format(@"exec h_p_jit_PPBOMList '{0}'", fDayPlanFids); + List<DayPlanPickedModel> DayPlanPickedModel = new List<DayPlanPickedModel>(); + ds = oCN.RunProcReturn(LLsql, "SC_WORKBILLSORTBILLMAIN"); + DayPlanPickedModel = ds.ToModelList<DayPlanPickedModel>(); + //CompleteAnalysisTempModel 鐢ㄤ簬瀛樺偍涓存椂闇�瑕佹彃鍏ユ暟鎹� + List<CompleteAnalysisTempModel> completeAnalysisTempModel = new List<CompleteAnalysisTempModel>(); + //鍒涘缓瀛楀吀 鐢ㄤ簬鍌ㄥ瓨鐗╂枡 + 鍗犵敤鏁伴噺 + Dictionary<string, decimal> occupyDic = new Dictionary<string, decimal>(); + LogService.Write($"榻愬鍒嗘瀽锛屾暟鎹噯澶囬樁娈碉紝鐢ㄦ椂" + sw.Elapsed + "鎬昏鏁帮細" + BomList.Count); + LogService.Write($"榻愬鍒嗘瀽锛屾暟鎹噯澶囬樁娈碉紝鐢ㄦ椂" + sw.Elapsed + "鎬婚渶瑕佸惊鐜殑bom鏁伴噺锛�" + DatePlanList.Count); + + //绗竴涓惊鐜� 鏃ヨ鍒掑伐鍗曟槑缁� 涓�澶�+涓�涓伐鍗� 涓�涓惊鐜� + foreach (var item in DatePlanList) + { + //鏃ヨ鍒掔敤鏂欐竻鍗曟槑缁� 姣忎竴澶╃殑瀹為檯鐢ㄦ枡鎯呭喌 + var _BomList = BomList.Where(x => x.HMasterDate == item.HMasterDate && x.HICMOEntryID_Sec == item.HICMOEntryID_Sec).ToList(); + //姣忎竴涓墿鏂欒繘琛屽簱瀛樿绠� + foreach (var _item in _BomList) + { + //杞﹂棿浠撳簱 瀵圭収琛� 姣忎釜鏃ヨ鍒掑悓灞炰竴涓溅闂� A,B + var _pRD_WorkHouseCompar = pRD_WorkHouseCompar.Where(c => c.FWORKSHOPID == _item.HWorkShopID).ToList(); + decimal jskcQty = 0;//鐢ㄤ簬璁$畻 + decimal jskcQty2 = 0;//鐢ㄤ簬璁$畻褰撴椂閭d釜璁$畻鑺傜偣鐨勫嵆鏃跺簱瀛� + //璁$畻褰撳墠杩欏嚑涓粨搴撴�荤殑搴撳瓨閲� + if (_pRD_WorkHouseCompar.Count > 0) + { + foreach (var _WorkHouse in _pRD_WorkHouseCompar) + { + //搴撳瓨鏁版嵁鍖归厤 + List<PRD_Inventory> _ListInventory = ListInventory.Where(c => c.FNumber == _item.FNumber && c.FBASEQTY > 0 && c.FSTOCKID == _WorkHouse.FSTOCKID).ToList(); + if (_ListInventory.Count > 0) + { + foreach (var Inventory in _ListInventory) + { + jskcQty += Inventory.FBASEQTY; + } + } + } + } + //鎵惧嚭鐗╂枡琚叾瀹冭鍗曞崰鐢ㄦ暟閲� + decimal occupyMaterial = 0; + if (occupyDic.ContainsKey(_item.HWorkShopID + _item.FMATERIALID2)) + { + occupyMaterial = occupyDic[_item.HWorkShopID + _item.FMATERIALID2]; + } + //铏氭嫙鏃ヨ鍒掔敤鏂欐竻鍗� 闇�姹傛暟閲� + decimal planNeed = _item.PlanCount; //涓嶅弬涓庤绠� 鐢ㄤ簬璁板綍 + decimal need = _item.PlanCount;//鍙備笌璁$畻 + decimal FOccupyPickedCount = 0;//鍗犵敤棰嗘枡鍗曟暟閲� + //鎵惧埌棰嗙敤鏁伴噺 + var _DayPlanPickedModel = DayPlanPickedModel.Where(c => c.FPRDMOENTYID == _item.HICMOEntryID_Sec && c.FMATERIALID == _item.FMATERIALID2).FirstOrDefault(); + if (_DayPlanPickedModel.FRemainPickedQty >= need) + { + //棰嗘枡鏁伴噺婊¤冻浜嗗綋鍓嶈繖涓渶姹傞噺 鐩存帴榻愬 涓嶉渶瑕佸幓鍗犵敤浠撳簱 + completeAnalysisTempModel.Add(new CompleteAnalysisTempModel + { + FHMainICMOInterIDr = _item.HICMOInterID_Sec, + FHMainICMOEntryID = _item.HICMOEntryID_Sec, + FHICMOInterID = _item.HInterID.ToString(), + FHICMOEntryID = _item.HEntryID.ToString(), + FHMaterID = _item.FMATERIALID2, + FErpClsID = _item.FErpClsID, + FHStockOrgID = _item.FStockOrgId, + FHPRDORGID = _item.FStockOrgId, + FPRDBillNo = _item.HICMOBillNo, + HMainICMOBillNo = _item.HMainICMOBillNo, + FOwnerTypeId = "", + FUnitDosage = _item.dwyl,//鍗曚綅鐢ㄩ噺 + FSumPlanCount = planNeed,//璁″垝鎬绘暟閲� + FCompleteCount1 = planNeed, //榻愬鏁伴噺 + FLackCount = 0,//缂烘枡鏁伴噺 + FHStockQty = jskcQty2,//鍗虫椂搴撳瓨 + FHLeftQty = jskcQty,//鍙敤鏁伴噺 + FOccupyCount = occupyMaterial,//鍗犵敤鏁伴噺 + FOccupyPickedCount = planNeed,//鍗犵敤棰嗘枡鏁伴噺 + FComPlete = "榻愬", + FPlanDate = item.HMasterDate, // 鏃ヨ鍒掓棩鏈� + FWorkShop = _item.HWorkShopID //杞﹂棿 + }); + //鎵i櫎鍓╀綑鍙敤棰嗘枡鏁伴噺 + _DayPlanPickedModel.FRemainPickedQty -= need; + //寰幆涓嬩竴涓墿鏂� + continue; + } + else + { + need -= _DayPlanPickedModel.FRemainPickedQty; //鍓╀綑闇�姹傛暟閲� + FOccupyPickedCount = _DayPlanPickedModel.FRemainPickedQty; + _DayPlanPickedModel.FRemainPickedQty = 0; + } + if (_pRD_WorkHouseCompar.Count > 0) + { + //缂烘枡鏁伴噺 闇�姹傛暟閲� - 瀹為檯搴撳瓨 >0 ? 涓�涓墿鏂欎笉绠″崰鐢ㄥ灏戞潯 搴撳瓨+璐т富 鏁版嵁 缂烘枡鏁伴噺鏄悓涓�涓暟閲� + decimal _fLackCount = need > jskcQty ? (need - jskcQty) : 0; + //LogHelper.Info("缁勭粐锛�" + _item.FStockOrgId + " ,鍙婃椂搴撳瓨" + jskcQty); + //鎬诲簱瀛樹负0浜� 鐩存帴缁欏嚭 缂烘枡鏁伴噺 + if (jskcQty == 0) + { + completeAnalysisTempModel.Add(new CompleteAnalysisTempModel + { + FHMainICMOInterIDr = _item.HICMOInterID_Sec, + FHMainICMOEntryID = _item.HICMOEntryID_Sec, + FHICMOInterID = _item.HInterID.ToString(), + FHICMOEntryID = _item.HEntryID.ToString(), + FHMaterID = _item.FMATERIALID2, + FErpClsID = _item.FErpClsID, + FHStockOrgID = _item.FStockOrgId, + FHPRDORGID = _item.FStockOrgId, + FPRDBillNo = _item.HICMOBillNo, + HMainICMOBillNo = _item.HMainICMOBillNo, + FOwnerTypeId = "", + FUnitDosage = _item.dwyl,//鍗曚綅鐢ㄩ噺 + FSumPlanCount = planNeed,//璁″垝鎬绘暟閲� + FCompleteCount1 = FOccupyPickedCount, //榻愬鏁伴噺 + FLackCount = need,//缂烘枡鏁伴噺 + FHStockQty = jskcQty2,//鍗虫椂搴撳瓨 + FHLeftQty = jskcQty,//鍙敤鏁伴噺 + FOccupyCount = occupyMaterial,//鍗犵敤鏁伴噺 + FOccupyPickedCount = FOccupyPickedCount,//鍗犵敤棰嗘枡鏁伴噺 + FComPlete = "鏈綈濂�", + FPlanDate = item.HMasterDate, // 鏃ヨ鍒掓棩鏈� + FWorkShop = _item.HWorkShopID //杞﹂棿 + }); + //缁堟璇ョ墿鏂欒绠� 杩涘叆涓嬩竴涓� + continue; + } + foreach (var WorkHouse in _pRD_WorkHouseCompar) + { + //搴撳瓨鏁版嵁鍖归厤 + List<PRD_Inventory> _ListInventory = ListInventory.Where(c => c.FNumber == _item.FNumber && c.FBASEQTY > 0 && c.FSTOCKID == WorkHouse.FSTOCKID).ToList(); + //闇�姹傛暟閲� 鍗犵敤瀹屽悗鍙互璺冲嚭杞﹂棿浠撳簱寰幆 + if (need == 0) + break; + if (_ListInventory.Count > 0) + { + foreach (var Inventory in _ListInventory) + { + if (need == 0) + break; + //榻愬鏁伴噺 + decimal fCompleteCount = need >= Inventory.FBASEQTY ? Inventory.FBASEQTY : need; + if (!occupyDic.ContainsKey(_item.HWorkShopID + _item.FMATERIALID2)) + { + occupyDic.Add(_item.HWorkShopID + _item.FMATERIALID2, fCompleteCount); + } + else + { + occupyMaterial = occupyDic[_item.HWorkShopID + _item.FMATERIALID2]; + occupyDic[_item.HWorkShopID + _item.FMATERIALID2] = occupyMaterial + fCompleteCount; + } + completeAnalysisTempModel.Add(new CompleteAnalysisTempModel + { + FHMainICMOInterIDr = _item.HICMOInterID_Sec, + FHMainICMOEntryID = _item.HICMOEntryID_Sec, + FHICMOInterID = _item.HInterID.ToString(), + FHICMOEntryID = _item.HEntryID.ToString(), + FHMaterID = _item.FMATERIALID2, + FHStockOrgID = _item.FStockOrgId, + FHPRDORGID = _item.FStockOrgId, + FErpClsID = _item.FErpClsID, + FPRDBillNo = _item.HICMOBillNo, + HMainICMOBillNo = _item.HMainICMOBillNo, + FOwnerTypeId = Inventory.FOwnerTypeId, + FOwnerId = Inventory.FOwnerId, + FUnitDosage = _item.dwyl,//鍗曚綅鐢ㄩ噺 + FSumPlanCount = planNeed,//璁″垝鎬绘暟閲� + FCompleteCount1 = fCompleteCount + FOccupyPickedCount, //榻愬鏁伴噺 + FLackCount = _fLackCount,//缂烘枡鏁伴噺 + FHStockQty = jskcQty2,//鍗虫椂搴撳瓨 + FHLeftQty = jskcQty,//鍙敤鏁伴噺 + FOccupyCount = occupyMaterial,//鍗犵敤鏁伴噺 + FOccupyPickedCount = FOccupyPickedCount,//棰嗘枡鍗犵敤鏁伴噺 + FComPlete = jskcQty >= need ? "榻愬" : "鏈綈濂�", + FPlanDate = item.HMasterDate, // 鏃ヨ鍒掓棩鏈� + FStock = Inventory.FSTOCKID,//浠撳簱 + FWorkShop = _item.HWorkShopID, //杞﹂棿 + HLOT = Inventory.HLOT, //鎵瑰彿 + HInventoryFID = Inventory.HInventoryFID //id + }); + //鎵e噺鎬诲簱瀛樻暟閲� + jskcQty = jskcQty >= fCompleteCount ? jskcQty - fCompleteCount : 0; + //鍓╀綑鏃ヨ鍒掗渶姹傛暟閲� + need = need >= Inventory.FBASEQTY ? need - Inventory.FBASEQTY : 0; + //鎵e噺娑堣�楀簱瀛� + Inventory.FBASEQTY = Inventory.FBASEQTY - fCompleteCount; + } + } + } + } + //娌℃湁杞﹂棿浠撳簱鏁版嵁 鏃㈡病鏈夊彲鐢ㄥ簱瀛� 涓烘湭榻愬 + else + { + if (occupyDic.ContainsKey(_item.HWorkShopID + _item.FMATERIALID2)) + { + occupyMaterial = occupyDic[_item.HWorkShopID + _item.FMATERIALID2]; + } + completeAnalysisTempModel.Add(new CompleteAnalysisTempModel + { + FHMainICMOInterIDr = _item.HICMOInterID_Sec, + FHMainICMOEntryID = _item.HICMOEntryID_Sec, + FHICMOInterID = _item.HInterID.ToString(), + FHICMOEntryID = _item.HEntryID.ToString(), + FHMaterID = _item.FMATERIALID2, + FErpClsID = _item.FErpClsID, + FHStockOrgID = _item.FStockOrgId, + FHPRDORGID = _item.FStockOrgId, + FPRDBillNo = _item.HICMOBillNo, + HMainICMOBillNo = _item.HMainICMOBillNo, + FOwnerTypeId = "", + FUnitDosage = _item.dwyl,//鍗曚綅鐢ㄩ噺 + FSumPlanCount = planNeed,//璁″垝鎬绘暟閲� + FCompleteCount1 = planNeed - need, //榻愬鏁伴噺 + FLackCount = need,//缂烘枡鏁伴噺 + FHStockQty = jskcQty2,//鍗虫椂搴撳瓨 + FHLeftQty = jskcQty,//鍙敤鏁伴噺 + FOccupyCount = occupyMaterial,//鍗犵敤鏁伴噺 + FOccupyPickedCount = FOccupyPickedCount,//鍗犵敤棰嗘枡鏁伴噺 + FComPlete = "鏈綈濂�", + FPlanDate = item.HMasterDate, // 鏃ヨ鍒掓棩鏈� + FWorkShop = _item.HWorkShopID //杞﹂棿 + }); + } + } + //Thread.Sleep(6000); + i++; + } + LogService.Write($"榻愬鍒嗘瀽锛屾暟鎹噯澶囧畬鎴愶紝淇濆瓨鍒癕odel瀹炰綋锛屾�昏鏁帮細{completeAnalysisTempModel.Count}锛岃�楁椂锛�" + sw.Elapsed); + List<string> sqlList = new List<string>(); + DataTable insertDT = new DataTable(); + insertDT.TableName = "JIT_MOMaterReadysBill"; + insertDT.Columns.Add("FID", typeof(long)); + insertDT.Columns.Add("FDOCUMENTSTATUS", typeof(string)); + insertDT.Columns.Add("FHMAINICMOINTERIDR", typeof(long)); + insertDT.Columns.Add("FHMAINICMOENTRYID", typeof(long)); + insertDT.Columns.Add("FHICMOINTERID", typeof(long)); + insertDT.Columns.Add("FHICMOENTRYID", typeof(long)); + insertDT.Columns.Add("FHMATERID", typeof(long)); + insertDT.Columns.Add("FHSTOCKORGID", typeof(long)); + insertDT.Columns.Add("FHSTOCKQTY", typeof(decimal)); + insertDT.Columns.Add("FHLEFTQTY", typeof(decimal)); + insertDT.Columns.Add("FHPRDORGID", typeof(long)); + insertDT.Columns.Add("FUNITDOSAGE", typeof(decimal)); + insertDT.Columns.Add("FSUMPLANCOUNT", typeof(decimal)); + insertDT.Columns.Add("FPRDBILLNO", typeof(string)); + insertDT.Columns.Add("HMainICMOBillNo", typeof(string)); + insertDT.Columns.Add("FOWNERID", typeof(long)); + insertDT.Columns.Add("FOWNERTYPEID", typeof(string)); + insertDT.Columns.Add("FPLANDATE", typeof(DateTime)); + insertDT.Columns.Add("FCOMPLETE", typeof(string)); + insertDT.Columns.Add("FLACKCOUNT", typeof(decimal)); + insertDT.Columns.Add("FOCCUPYCOUNT", typeof(decimal)); + insertDT.Columns.Add("FCOMPLETECOUNT1", typeof(decimal)); + insertDT.Columns.Add("FERPCLSID", typeof(string)); + insertDT.Columns.Add("FWORKSHOPID", typeof(long)); + insertDT.Columns.Add("FSTOCKID", typeof(long)); + insertDT.Columns.Add("FOCCUPYPICKEDCOUNT", typeof(decimal)); + insertDT.Columns.Add("HLOT", typeof(long)); + insertDT.Columns.Add("HInventoryFID", typeof(string)); + int jdtmmm = 1; + ds = oCN.RunProcReturn("select max(HInterID)FID FROM JIT_MOMaterReadysBill", "JIT_MOMaterReadysBill"); + int maxFid = int.Parse(ds.Tables[0].Rows[0][0].ToString() == "" ? "0" : ds.Tables[0].Rows[0][0].ToString()); + foreach (var item in completeAnalysisTempModel) + { + DataRow dr = insertDT.NewRow(); + dr["FID"] = maxFid + jdtmmm; + dr["FDOCUMENTSTATUS"] = "A"; + dr["FHMAINICMOINTERIDR"] = item.FHMainICMOInterIDr; + dr["FHMAINICMOENTRYID"] = item.FHMainICMOEntryID; + dr["FHICMOINTERID"] = item.FHICMOInterID; + dr["FHICMOENTRYID"] = item.FHICMOEntryID; + dr["FHMATERID"] = item.FHMaterID; + dr["FHSTOCKORGID"] = item.FHStockOrgID; + dr["FHSTOCKQTY"] = item.FHStockQty; + dr["FHLEFTQTY"] = item.FHLeftQty; + dr["FHPRDORGID"] = item.FHPRDORGID; + dr["FUNITDOSAGE"] = item.FUnitDosage; + dr["FSUMPLANCOUNT"] = item.FSumPlanCount; + dr["FPRDBILLNO"] = item.FPRDBillNo; + dr["HMainICMOBillNo"] = item.HMainICMOBillNo; + dr["FOWNERID"] = item.FOwnerId == null ? "0" : item.FOwnerId; + dr["FOWNERTYPEID"] = item.FOwnerTypeId; + dr["FPLANDATE"] = item.FPlanDate.ToString("yyyy-MM-dd"); + dr["FCOMPLETE"] = item.FComPlete; + dr["FLACKCOUNT"] = item.FLackCount; + dr["FOCCUPYCOUNT"] = item.FOccupyCount; + dr["FCOMPLETECOUNT1"] = item.FCompleteCount1; + dr["FERPCLSID"] = item.FErpClsID; + dr["FWORKSHOPID"] = item.FWorkShop == null ? "0" : item.FWorkShop; + dr["FSTOCKID"] = item.FStock == null ? "0" : item.FStock; + dr["FOCCUPYPICKEDCOUNT"] = item.FOccupyPickedCount; + dr["HLOT"] = item.HLOT == null? "0" : item.HLOT; + dr["HInventoryFID"] = item.HInventoryFID == null ? "0" : item.HInventoryFID; + insertDT.Rows.Add(dr); + jdtmmm++; + } + + insertDT.EndLoadData(); // 鐏屽叆鏁版嵁缁撴潫 + //鎻掑叆涔嬪墠鎵ц涓嬫竻绌鸿鍙�(娴嬭瘯鏄惁鑳藉闃叉閲嶅鐢熸垚) + string deletesql = $"delete from JIT_MOMaterReadysBill where HICMOInterID in ({fDayPlanFids}) "; + oCN.RunProc(deletesql); + // 鎵归噺鎻掑叆鍒版暟鎹簱 + foreach (DataRow item in insertDT.Rows) + { + oCN.RunProc("insert into JIT_MOMaterReadysBill(HInterID,HDocumentStatus,HMainICMOInterID,HMainICMOEntryID,HICMOInterID" + + ", HICMOEntryID, HMaterID, HStockORGID, HStockQty, HLeftQty" + + ", HProdORGID, HUnitDosage, HSumPlanQty, HICMOBillNo, HOwnerID" + + ", HOwnerTypeID, HPlanDate, HComplete, HLackQty, HOccupyQty" + + ", HCompleteQty1, HErpClsID, HWorkShopID, HWHID, HOccupyPickedQTY,HMainICMOBillNo" + + ",HLOT,HInventoryFID)values" + + $"({item["FID"].ToString()}, 1, {item["FHMAINICMOINTERIDR"].ToString()}, {item["FHMAINICMOENTRYID"].ToString()}, {item["FHICMOINTERID"].ToString()}" + + $", {item["FHICMOENTRYID"].ToString()}, {item["FHMATERID"].ToString()}, {item["FHSTOCKORGID"].ToString()}, {item["FHSTOCKQTY"].ToString()}, {item["FHLEFTQTY"].ToString()}" + + $" , {item["FHPRDORGID"].ToString()}, {item["FUNITDOSAGE"].ToString()}, {item["FSUMPLANCOUNT"].ToString()}, '{item["FPRDBILLNO"].ToString()}', {item["FOWNERID"].ToString()}" + + $", '{item["FOWNERTYPEID"].ToString()}', '{item["FPLANDATE"].ToString()}','{item["FCOMPLETE"].ToString()}', {item["FLACKCOUNT"].ToString()}, {item["FOCCUPYCOUNT"].ToString()}" + + $", {item["FCOMPLETECOUNT1"].ToString()}, {item["FERPCLSID"].ToString()}, {item["FWORKSHOPID"].ToString()}, {item["FSTOCKID"].ToString()}, {item["FOCCUPYPICKEDCOUNT"].ToString()}, '{item["HMainICMOBillNo"].ToString()}'" + + $",{item["HLOT"].ToString()},'{item["HInventoryFID"].ToString()}')"); + } + LogService.Write("鎵归噺鎻掑叆鍒版暟鎹簱鐢ㄦ椂锛�" + sw.Elapsed); + //鎵ц瀹屾垚鍚� 鏇存柊鏃ヨ鍒掑伐鍗曠姸鎬� + string updatesql = string.Format(@" +update Sc_WorkBillSortBillSub set HComplete = '鏈綈濂�' where HEntryID IN +(select distinct HICMOEntryID from JIT_MOMaterReadysBill + where isnull(HComplete,'鏈綈濂�') ='鏈綈濂�' + and HICMOEntryID in ({0}) + )", fDayPlanFEntryids); + //LogService.Write(Context, updatesql); + oCN.RunProc(updatesql); + updatesql = string.Format(@" +update Sc_WorkBillSortBillSub set HComplete = '榻愬' +where HEntryID IN ({0}) and HComplete <>'鏈綈濂�' +", fDayPlanFEntryids); + //LogService.Write(updatesql); + oCN.RunProc(updatesql); + //閲婃斁榻愬鎿嶄綔 閬垮厤澶氫汉鍚屾椂杩涜榻愬鍒嗘瀽 + oCN.RunProc($"update T_PRD_QTFX set FSTATUS = 0 where FPRDORGID ={omdelMian.HProdORGID} and FSTATUS = 1 "); + sw.Stop();//缁撴潫璁℃椂 + LogService.Write("榻愬鍒嗘瀽杩愯鎬绘椂闀匡細" + sw.Elapsed); + + objJsonResult.code = "1"; + objJsonResult.count = 1; + objJsonResult.Message = "鎿嶄綔鎴愬姛"; + objJsonResult.data = null; + return objJsonResult; + } + catch (Exception e) + { + LogService.Write("鎿嶄綔澶辫触锛�" + e.Message.ToString()); + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "Exception锛�" + e.Message.ToString(); + objJsonResult.data = null; + return objJsonResult; + } + } + #endregion + + #region 鐢熶骇鏃ヨ鍒掑钩鍙� 鎻愭枡杩愮畻 + + #region 鏃ヨ鍒掑睍寮�鏁版嵁鏄庣粏 + public class DayPlanPpbom + { + + /// <summary> + /// 鏃ヨ鍒掑伐鍗曚富ID + /// </summary> + public long FID { get; set; } + /// <summary> + /// 鐢熶骇璁㈠崟鍙� + /// </summary> + public string FBILLNO { get; set; } + /// <summary> + /// 鏃ヨ鍒掓槑缁嗘棩鏈� + /// </summary> + public DateTime FHMASTERDATE { get; set; } + /// <summary> + /// 鏃ヨ鍒掓槑缁嗘暟閲� + /// </summary> + public decimal FHQTY { get; set; } + /// <summary> + /// 榻愬鏁� + /// </summary> + public decimal FCOMPLETECOUNT { get; set; } + /// <summary> + /// 鐢熶骇璁㈠崟宸ュ崟ID + /// </summary> + public long FPRDMOMAINID { get; set; } + /// <summary> + /// 瀛愯〃ID + /// </summary> + public int FENTRYID { get; set; } + /// <summary> + /// 鍗曚綅鐢ㄦ枡 + /// </summary> + public decimal FNeedQty { get; set; } + /// <summary> + /// 鐗╂枡ID + /// </summary> + public string FMATERIALID { get; set; } + /// <summary> + /// 鎻愬墠澶╂暟 + /// </summary> + public int FFIXLEADTIME { get; set; } + /// <summary> + ///鏈�澶у寘瑁� + /// </summary> + public decimal FMAXPOQTY { get; set; } + /// <summary> + /// 鏈�灏忓寘瑁呴噺 + /// </summary> + public decimal FMINPOQTY { get; set; } + /// <summary> + /// 鐗╂枡缂栫爜 + /// </summary> + public string FNumber { get; set; } + /// <summary> + /// 瀹為檯闇�姹� + /// </summary> + public decimal NeedQty { get; set; } + + /// <summary> + /// 搴撳瓨缁勭粐 + /// </summary> + public long FStockOrgId { get; set; } + //搴撳瓨缁勭粐鍚嶇О + public string FStockOrgName { get; set; } + /// <summary> + /// jit鐗╂枡鍒嗙被 + /// </summary> + public string FJITmaterialGroup { get; set; } + /// <summary> + /// JIT鐗╂枡闇�姹備緵璐у懆鏈� + /// </summary> + public string FJITMaterielDemand { get; set; } + /// <summary> + /// JIT瀹夊叏搴撳瓨 + /// </summary> + public string FJITSafeStock { get; set; } + + /// <summary> + /// 鐗╂枡灞炴�� + /// </summary> + public string FErpClsID { get; set; } + /// <summary> + /// 闇�姹傚崟鍙凤紙閿�鍞鍗曞彿锛� + /// </summary> + public string FXQD { get; set; } + /// <summary> + /// 鏃ヨ鍒掑伐鍗曞崟鍙� + /// </summary> + public string FDAYPLANBILLNO { get; set; } + /// <summary> + /// 鐢熶骇杞﹂棿缂栫爜 + /// </summary> + public string FWORKSHOPNUMBER { get; set; } + + + } + #endregion + + #region 閲囪喘璁㈠崟鐗╂枡搴撳瓨 + public class PurchaseInventory + { + /// <summary> + /// 閲囪喘FID + /// </summary> + public long FID { get; set; } + //閲囪喘璁㈠崟鍗曞彿 + public string FBillNo { get; set; } + /// <summary> + /// 閲囪喘瀛愯〃鏍囪瘑 + /// </summary> + public long FENTRYID { get; set; } + /// <summary> + /// 渚涘簲鍟唅d + /// </summary> + public long FSUPPLIERID { get; set; } + /// <summary> + /// 渚涘簲鍟嗗悕绉� + /// </summary> + public string FNUMBER { get; set; } + /// <summary> + /// 鐗╂枡ID + /// </summary> + public string FMATERIALID { get; set; } + /// <summary> + /// 鐗╂枡缂栫爜 + /// </summary> + public string FMATERIALNUMBER { get; set; } + + /// <summary> + /// 閲囪喘鏁伴噺 + /// </summary> + public decimal FQTY { get; set; } + + /// <summary> + /// 閲囪喘缁勭粐 + /// </summary> + public long FStockOrgId { get; set; } + /// <summary> + /// 閲囪喘缁勭粐鍚嶇О + /// </summary> + public string FStockOrgName { get; set; } + /// <summary> + /// 缁勭粐缂栫爜 + /// </summary> + public string FORGNumber { get; set; } + /// <summary> + /// 鎻愬墠鏈� + /// </summary> + public int FFIXLEADTIME { get; set; } + + /// <summary> + /// 闇�姹傚崟鍙� + /// </summary> + public string FXQD { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟涓婄殑鍒涘缓浜� + /// </summary> + public string FCREATORID { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟涓婄殑鍒涘缓浜哄悕绉� + /// </summary> + public string FName { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟涓婄殑閲囪喘鏃ユ湡 + /// </summary> + public DateTime FDate { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟涓婄殑浜よ揣鏃ユ湡 + /// </summary> + public DateTime FDeliveryDate { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟琛ㄥご鎽樿 + /// </summary> + public string F_QIMB_NOTE { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟琛ㄤ綋澶囨敞 + /// </summary> + public string FNOTE { get; set; } + //閲囪喘閮ㄩ棬 + public string FPURCHASEDEPTNUMBER { get; set; } + + /// <summary> + /// 鏀舵枡浣嗘槸娌″叆搴撻儴鍒� 闇�瑕佷紭鍏堝幓鎵i櫎 + /// </summary> + public decimal FReceiveNotInQty { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟鏁伴噺 + /// </summary> + public decimal FPURCHASEQTY { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟鍏宠仈鏁伴噺 + /// </summary> + public decimal FJOINQTY { get; set; } + + /// <summary> + /// 鏀舵枡鍗曟暟閲� + /// </summary> + public decimal FReceiveQty { get; set; } + } + #endregion + + #region 鎻愭枡璁″垝涓存椂鍌ㄥ瓨 + public class PODemandPlanTemp + { + /// <summary> + /// 鏃ヨ鍒掑伐鍗曚富ID + /// </summary> + public long FID { get; set; } + /// <summary> + /// 鏃ヨ鍒掑伐鍗曠紪鍙� + /// </summary> + public string FBILLNO { get; set; } + /// <summary> + /// 鏃ヨ鍒掓槑缁嗘棩鏈� + /// </summary> + public DateTime FHMASTERDATE { get; set; } + /// <summary> + /// 鏃ヨ鍒掓槑缁嗘暟閲� + /// </summary> + public decimal FHQTY { get; set; } + /// <summary> + /// 鐢熶骇璁㈠崟宸ュ崟ID + /// </summary> + public long FPRDMOMAINID { get; set; } + /// <summary> + /// 瀛愯〃ID + /// </summary> + public int FENTRYID { get; set; } + /// <summary> + /// 鏁伴噺 + /// </summary> + public decimal FQty { get; set; } + /// <summary> + /// 鐗╂枡ID + /// </summary> + public string FMATERIALID { get; set; } + /// <summary> + /// 鐗╂枡缂栫爜 + /// </summary> + public string FNumber { get; set; } + + /// <summary> + /// 閲囪喘FID + /// </summary> + public long PurchseFID { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟鍗曞彿 + /// </summary> + public string PurchseFBillNo { get; set; } + /// <summary> + /// 閲囪喘瀛愯〃鏍囪瘑 + /// </summary> + public long PurchseFentryID { get; set; } + /// <summary> + /// 渚涘簲鍟唅d + /// </summary> + public long FSUPPLIERID { get; set; } + /// <summary> + /// 渚涘簲鍟嗗悕绉� + /// </summary> + public string PurchseFNUMBER { get; set; } + + /// <summary> + /// 鏃ヨ鍒掓棩鏈� + /// </summary> + public DateTime OLDDATE { get; set; } + + /// <summary> + /// 閲囪喘璁㈠崟鏁伴噺 + /// </summary> + public decimal PurchseFqty { get; set; } + + /// <summary> + /// 鎻愬墠鏈� + /// </summary> + public double FFIXLEADTIME { get; set; } + + /// <summary> + /// 閲囪喘缁勭粐 + /// </summary> + public long FStockOrgId { get; set; } + /// <summary> + /// 閲囪喘缁勭粐鍚嶇О + /// </summary> + public string FStockOrgName { get; set; } + /// <summary> + /// 缁勭粐缂栫爜 + /// </summary> + public string FORGNumber { get; set; } + + /// <summary> + /// 鐗╂枡灞炴�� + /// </summary> + public string FErpClsID { get; set; } + + /// <summary> + /// 闇�姹傚崟鍙� + /// </summary> + public string FXQD { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟涓婄殑鍒涘缓浜� + /// </summary> + public string FCREATORID { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟涓婄殑鍒涘缓浜哄悕绉� + /// </summary> + public string FName { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟涓婄殑閲囪喘鏃ユ湡 + /// </summary> + public DateTime FDate { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟涓婄殑浜よ揣鏃ユ湡 + /// </summary> + public DateTime FDeliveryDate { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟琛ㄥご鎽樿 + /// </summary> + public string F_QIMB_NOTE { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟琛ㄤ綋澶囨敞 + /// </summary> + public string FNOTE { get; set; } + + /// <summary> + /// 閲囪喘閮ㄩ棬 + /// </summary> + public string FPURCHASEDEPTNUMBER { get; set; } + /// <summary> + /// 鏃ヨ鍒掑伐鍗曞崟鍙� + /// </summary> + public string FDAYPLANBILLNO { get; set; } + /// <summary> + /// 鐢熶骇杞﹂棿缂栫爜 + /// </summary> + public string FWORKSHOPNUMBER { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟鏁伴噺 + /// </summary> + public decimal FPURCHASEQTY { get; set; } + /// <summary> + /// 閲囪喘璁㈠崟鍏宠仈鏁伴噺 + /// </summary> + public decimal FJOINQTY { get; set; } + } + #endregion + + [Route("JIT_DayPlanPlatFormBill/JIT_TLYS")] + [HttpGet] + public object JIT_TLYS(string sWhere, string user,string HTLType) + { + try + { + omdelMian = JsonConvert.DeserializeObject<Sc_WorkBillSortBillMain>(sWhere); + + string fProWorkShopId = omdelMian.HWorkShopID.ToString(); + var fPrdOrgId = omdelMian.HProdORGID; + string sqlName = "";//AIS20210811135644 + //瀹㈡埛鍒跺畾 + string sErr = ""; + if (oSystemParameter.ShowBill(ref sErr)) + { + if (oSystemParameter.omodel.WMS_CampanyName == "甯呭▉") + { + sqlName = "AIS20230129011339"; + } + else + { + sqlName = "AIS20210811135644"; + } + } + + if (HTLType == "缂烘枡") + { + objJsonResult = (json)JIT_QL(fProWorkShopId, fPrdOrgId, user, sqlName); + } + else if (HTLType == "鐢熶骇鐢ㄦ枡娓呭崟") + { + objJsonResult=(json)JIT_PPBOM(fProWorkShopId, fPrdOrgId, user, sqlName); + } + + return objJsonResult; + } + catch (Exception e) + { + LogService.Write("鎿嶄綔澶辫触锛�" + e.Message.ToString()); + oCN.RollBack();//浜嬪姟鍥炴粴 + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "Exception锛�" + e.Message.ToString(); + objJsonResult.data = null; + return objJsonResult; + } + } + + /// <summary> + /// 閫氳繃缂烘枡鎯呭喌绠楁彁鏂� + /// </summary> + /// <returns></returns> + public object JIT_QL(string HWorkShopID,int? HProdORGID,string user,string sqlName) { + try + { + + oCN.BeginTran(); + + DataSet DaSet = oCN.RunProcReturn($"exec h_p_JIT_MOMaterReady {HWorkShopID},{HProdORGID},1", "JIT_MOMaterReadysBill"); + + if (DaSet.Tables[0].Rows[0][0].ToString() != "1") + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "娌℃湁鏁版嵁,璇峰厛榻愬鍒嗘瀽!"; + objJsonResult.data = null; + return objJsonResult; + } + + //Stopwatch sw = new Stopwatch(); + //sw.Start();//寮�濮嬭鏃� + //鎻愭枡璁″垝棰勫鐞� 娓呯悊鎻愭枡璁″垝鍗曟暟鎹� 鏇存柊閲囪喘璁㈠崟鎻愭枡璁″垝鏁伴噺 + // string sql = string.Format(@" + // /*dialect*/ + //exec [鎻愭枡璁″垝棰勫鐞哴 + //"); + // DBServiceHelper.Execute(Context, sql); + ////LogHelper.Info("[鎻愭枡璁″垝鍑嗗闃舵]鎻愭枡璁″垝棰勫鐞唖ql锛�" + sql); + //閲囪喘璁㈠崟鏁版嵁 + string sql = $@"exec h_p_JIT_MOMaterReady {HWorkShopID},{HProdORGID},2"; + DataSet ds = oCN.RunProcReturn(sql, "t_PUR_POOrderEntry"); + List<PurchaseInventory> PurchaseInventory = ds.ToModelList<PurchaseInventory>(); + ////LogHelper.Info("[鎻愭枡璁″垝鍑嗗闃舵]鍙敤閲囪喘璁㈠崟鏁版嵁sql锛�" + sql); + sql = string.Format($@"exec h_p_JIT_MOMaterReady {HWorkShopID},{HProdORGID},3"); + ////LogHelper.Info("[鎻愭枡璁″垝鍑嗗闃舵]闇�瑕佹彁鏂欐暟鎹畇ql锛�" + sql); + ds = oCN.RunProcReturn( sql, "JIT_MOMaterReadysBill"); + List<DayPlanPpbom> DayPlanPpbom = ds.ToModelList<DayPlanPpbom>(); + //鐗╂枡+搴撳瓨缁勭粐鍒嗙被 + var MaterialIDList = DayPlanPpbom.GroupBy(p => new { p.FMATERIALID, p.FNumber,p.FStockOrgName, p.FStockOrgId }).Select(x => new PODemandPlanTemp { FMATERIALID = x.Key.FMATERIALID, FNumber=x.Key.FNumber, FStockOrgId = x.Key.FStockOrgId , FStockOrgName =x.Key.FStockOrgName }).ToList(); + //鎻愭枡璁″垝鏁版嵁闆嗕复鏃跺瓨鍌ㄩ泦鍚� + List<PODemandPlanTemp> PODemandPlanTemp = new List<PODemandPlanTemp>(); + //sql闆嗗悎 鏇存柊閲囪喘璁㈠崟鍗犵敤鐨勬彁鏂欒鍒掓暟閲� + List<string> sqlList = new List<string>(); + string Error = "杩愮畻澶辫触!"; + foreach (var item in MaterialIDList) + { + //褰撳墠鐗╂枡娌℃湁閲囪喘璁㈠崟鏃� 鐩存帴璺冲嚭 + List<PurchaseInventory> _PurchaseInventory = PurchaseInventory.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId && x.FQTY > 0).OrderBy(x => x.FENTRYID).ToList(); + if (_PurchaseInventory.Count == 0) + { + Error+="[鎻愭枡璁″垝寮�濮媇褰撳墠鐗╂枡鏃犻噰璐俊鎭細" + item.FNumber + " 搴撳瓨缁勭粐锛�" + item.FStockOrgName + " "; + continue; + } + ////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;//鎻愬墠鏈� + //double FFIXLEADTIME = 3;//鎻愬墠鏈�(2022-1-26 鎻愬墠鏈熸敼涓�3澶� 涔冩案鍒氬弽棣�) + 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 = 0; + //璁板綍鍦ㄦ渶灏忛噰璐噺闇�姹備笅鐨勬棩璁″垝鏄庣粏FentyrID + List<int> FEntryIdList = new List<int>(); + foreach (var _item in _DayPlanPpbom) + { + i++; + _PurchaseInventory = PurchaseInventory.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId && x.FQTY > 0).OrderBy(x => x.FENTRYID).ToList(); + if (_PurchaseInventory.Count == 0) + { + break; + } + + 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) && i < _DayPlanPpbom.Count) //璁㈠崟涓撶敤涓�х被 + continue; + + foreach (var Purchase in _PurchaseInventory) + { + if (Purchase.FQTY >= NeedQty) + { + foreach (int id in FEntryIdList) + { + var DayPlanPpbomls = DayPlanPpbom.Where(c => c.FENTRYID == id && c.FMATERIALID == _item.FMATERIALID).FirstOrDefault(); + PODemandPlanTemp.Add(new 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, + FErpClsID = DayPlanPpbomls.FErpClsID, + + PurchseFID = Purchase.FID, + PurchseFentryID = Purchase.FENTRYID, + FSUPPLIERID = Purchase.FSUPPLIERID, + PurchseFNUMBER = Purchase.FNUMBER, + PurchseFBillNo = Purchase.FBillNo, + PurchseFqty = Purchase.FQTY, + FStockOrgId = Purchase.FStockOrgId, //閲囪喘缁勭粐 + FORGNumber = Purchase.FORGNumber, + + FXQD = _item.FXQD, + FCREATORID = Purchase.FCREATORID, + FName = Purchase.FName, + FDate = Purchase.FDate, + FDeliveryDate = Purchase.FDeliveryDate, + F_QIMB_NOTE = Purchase.F_QIMB_NOTE, + FNOTE = Purchase.FNOTE, + FPURCHASEQTY = Purchase.FPURCHASEQTY, + FJOINQTY = Purchase.FJOINQTY + }); + //鎵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 - Qty; + PODemandPlanTemp.Add(new 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, + FErpClsID = DayPlanPpbomls.FErpClsID, + + PurchseFID = Purchase.FID, + PurchseFentryID = Purchase.FENTRYID, + FSUPPLIERID = Purchase.FSUPPLIERID, + PurchseFNUMBER = Purchase.FNUMBER, + PurchseFBillNo = Purchase.FBillNo, + PurchseFqty = Purchase.FQTY, + FStockOrgId = Purchase.FStockOrgId, //閲囪喘缁勭粐 + FORGNumber = Purchase.FORGNumber, + + FPURCHASEDEPTNUMBER = Purchase.FPURCHASEDEPTNUMBER, + FXQD = _item.FXQD, + FCREATORID = Purchase.FCREATORID, + FName = Purchase.FName, + FDate = Purchase.FDate, + FDeliveryDate = Purchase.FDeliveryDate, + F_QIMB_NOTE = Purchase.F_QIMB_NOTE, + FNOTE = Purchase.FNOTE, + FPURCHASEQTY = Purchase.FPURCHASEQTY, + FJOINQTY = Purchase.FJOINQTY + }); + //鏇存柊璁″垝鏁伴噺锛堝墿浣欓渶瑕佹帓鐨勶級 缁х画鍘昏绠椾笅涓�涓噰璐鍗� + 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); + } + } + } + NeedQty = 0; + + } + } + //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(); + //LogHelper.Info($"鎻愭枡璁″垝锛屾暟鎹噯澶囧畬鎴愶紝淇濆瓨鍒癕odel瀹炰綋锛屾�昏鏁帮細{PODemandPlanTemp.Count}"); + int tlmmm = 0; + JArray FinalyResult = new JArray(); + + + foreach (var item in PODemandPlanList) + { + tlmmm++; + + DateTime date = item.FHMASTERDATE; + string PurchseFNUMBER = item.PurchseFNUMBER; + //JObject model = new JObject(); + //model.Add("FHDate", date); + //model.Add("FDeliveryDate", date.AddDays(-3));//渚涘簲鍟嗛璁″彂璐ф棩鏈� + //model.Add("FSettleCurrId", new JObject() { ["Fnumber"] = "PRE001" }); + //model.Add("FSupplierID", new JObject() { ["Fnumber"] = PurchseFNUMBER }); + + var HInterID = DBUtility.ClsPub.CreateBillID("4608", ref DBUtility.ClsPub.sExeReturnInfo); + var HBillNo = DBUtility.ClsPub.CreateBillCode("4608", ref DBUtility.ClsPub.sExeReturnInfo, true); + + var dataUser = oCN.RunProcReturn("select Czymc from gy_czygl where Czybm = '" + user + "'", "gy_czygl"); + string HMaker = dataUser.Tables[0].Rows.Count == 0 ? "" : dataUser.Tables[0].Rows[0][0].ToString();//鍒跺崟浜� + string HUpDater = dataUser.Tables[0].Rows.Count == 0 ? "" : dataUser.Tables[0].Rows[0][0].ToString();//淇敼浜� + + + var dataOrg = oCN.RunProcReturn(@"select HItemID from Xt_ORGANIZATIONS o + inner join "+ sqlName + @"..T_ORG_ORGANIZATIONS fo on o.HNumber=fo.FNUMBER + where FNUMBER='" + PODemandPlanTemp[0].FORGNumber + "' and HItemID ='" + HProdORGID + "'", "Xt_ORGANIZATIONS"); + long HPURCHASEORGID = dataOrg.Tables[0].Rows.Count == 0 ? 0 : long.Parse(dataOrg.Tables[0].Rows[0]["HItemID"].ToString()); //閲囪喘缁勭粐 + + var dataSup = oCN.RunProcReturn(@"select * from Gy_Supplier p + inner join " + sqlName + @"..t_BD_Supplier fp on p.HNumber=fp.FNUMBER and p.HUSEORGID=fp.FUSEORGID + where FNUMBER='" + item.PurchseFNUMBER + "' and HUSEORGID ='" + HProdORGID + "'", "Gy_Supplier"); + long HSupplierID = dataSup.Tables[0].Rows.Count == 0 ? 0 : long.Parse(dataSup.Tables[0].Rows[0]["HItemID"].ToString()); //渚涘簲鍟� + + long HSettleCurrId = 1;//璐у竵 榛樿鏈湴浜烘皯甯� + + //涓昏〃 + oCN.RunProc("insert into JIT_Cg_PODemandPlanBillMain(HInterID,HBillNo,HYear,HPeriod,HBillType" + + ",HBillSubType,HDate,HBillStatus,HMaker,HMakeDate" + + ",HSubORGID ,HAddress,HPURCHASEORGID,HSupplierID ,HSettleCurrId" + + ",HRemark,HExplanation,HUpDater,HUpDateDate)" + + $"values({HInterID}, '{HBillNo}', {DateTime.Now.Year}, {DateTime.Now.Month}, '4608'" + + $", '4608','{date}',1, '{HMaker}',GETDATE()," + + $"{HPURCHASEORGID},'',{HPURCHASEORGID}, {HSupplierID}, {HSettleCurrId}" + + $",'','','{HUpDater}',getdate())"); + + JArray Fentity = new JArray(); + List<PODemandPlanTemp> _PODemandPlanList = PODemandPlanTemp.Where(x => x.FHMASTERDATE == date && x.PurchseFNUMBER == PurchseFNUMBER).ToList(); + //LogService.Write("娴嬭瘯listmodel锛�" + _PODemandPlanList[0].FORGNumber.ToString()); + int i = 0; + foreach (var _item in _PODemandPlanList) + { + i++; + //if (!model.ToString().Contains("FHPURCHASEORGID")) + // model.Add("FHPURCHASEORGID", new JObject() { ["Fnumber"] = _item.FORGNumber }); + //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 + //FentityModel.Add("FERPCLSID", _item.FErpClsID); //鍙戞枡鏂瑰紡 + //FentityModel.Add("FUnitID", new JObject() { ["Fnumber"] = "Pcs" }); //鍙戞枡鏂瑰紡 + //Fentity.Add(FentityModel); + + + var dataSet = oCN.RunProcReturn(@"select m.* from Gy_Material m + inner join " + sqlName + @"..T_BD_MATERIAL fm on m.HNumber = fm.FNUMBER and m.HUSEORGID=fm.FUSEORGID + where FNUMBER='" + _item.FNumber + "' and HUSEORGID ='" + HProdORGID + "'", "Gy_Material"); + string HMaterID = "0"; //鐗╂枡 + string HMaterModel = ""; //鐗╂枡浠g爜 + string HMaterName = ""; //鐗╂枡鍚嶇О + if (dataSet.Tables[0].Rows.Count != 0) + { + HMaterID = dataSet.Tables[0].Rows[0]["HItemID"].ToString(); //鐗╂枡 + HMaterModel = dataSet.Tables[0].Rows[0]["HNumber"].ToString(); //鐗╂枡浠g爜 + HMaterName = dataSet.Tables[0].Rows[0]["HName"].ToString(); //鐗╂枡鍚嶇О + } + + decimal HQty = _item.FQty; //鏁伴噺 + long HSourceInterID = _item.FID; //鏃ヨ鍒掑伐鍗旻ID + long HSourceEntryID = _item.FENTRYID;//鏃ヨ鍒掑伐鍗旻ENTRYID + string HSourceBillNo = _item.FBILLNO; //鐢熶骇璁㈠崟鍙� + string HSourceBillType = ""; //鏃ヨ鍒掑伐鍗曠被鍨� + DateTime HDayPlanDate = _item.OLDDATE; // 宸ュ崟鐢熶骇鏃ユ湡 + decimal HRelationQty = _item.PurchseFqty; // 鍏宠仈鏁伴噺 + double HFixleadTime = _item.FFIXLEADTIME; // 鎻愬墠鏈� + + dataOrg = oCN.RunProcReturn(@"select HItemID from Xt_ORGANIZATIONS o + inner join " + sqlName + @"..T_ORG_ORGANIZATIONS fo on o.HNumber=fo.FNUMBER + where FNUMBER='" + _item.FORGNumber + "' and HItemID ='" + HProdORGID + "'", "Xt_ORGANIZATIONS"); + long HPURCHASEORGIDSub = dataOrg.Tables[0].Rows.Count == 0 ? 0 : long.Parse(dataOrg.Tables[0].Rows[0]["HItemID"].ToString()); // 閲囪喘缁勭粐 + long HPOOrderInterID = _item.PurchseFID; // 閲囪喘璁㈠崟鍐呯爜 + long HPOOrderEntryID = _item.PurchseFentryID; // 閲囪喘璁㈠崟瀛愬唴鐮� + string HPOOrderBillNo = _item.PurchseFBillNo; // 閲囪喘璁㈠崟鍙� + string HErpClsID = _item.FErpClsID; // 鐗╂枡灞炴�� + long HUnitID = 10101; // 璁¢噺鍗曚綅 鍏堟寜鐓ф湰鍦版潵 榛樿 Pcs + string HSeOrderBillNo = _item.FXQD; // 閿�鍞鍗曞彿 闇�姹傚崟鍙� + string HOrderEmpID = _item.FCREATORID; // 閲囪喘鍛� + DateTime HPOOrderBillDate = _item.FDate; // 閲囪喘璁㈠崟鍗曟嵁鏃ユ湡 + DateTime HPOOrderBillDeliveryDate = _item.FDeliveryDate; // 閲囪喘璁㈠崟浜よ揣鏃ユ湡 + string HPOOrderBillRemark = _item.F_QIMB_NOTE; // 閲囪喘璁㈠崟鎽樿 + string HPOOrderBillNote = _item.FNOTE; // 閲囪喘璁㈠崟琛ㄤ綋澶囨敞 + string HDayPlanBillNo = _item.FDAYPLANBILLNO; // 鏃ヨ鍒掑伐鍗曞彿 + + dataSet = oCN.RunProcReturn(@"select HItemID from Gy_Department d + inner join " + sqlName + @"..T_BD_DEPARTMENT fd on d.HNumber = fd.FNUMBER + where FNUMBER='" + _item.FWORKSHOPNUMBER + "' and HUSEORGID ='" + HProdORGID + "'", "Gy_Department"); + HWorkShopID = dataSet.Tables[0].Rows.Count == 0 ? "0" : dataSet.Tables[0].Rows[0][0].ToString(); // 鐢熶骇杞﹂棿 + + dataSet = oCN.RunProcReturn(@"select HItemID from Gy_Department d + inner join " + sqlName + @"..T_BD_DEPARTMENT fd on d.HNumber = fd.FNUMBER + where FNUMBER='" + _item.FPURCHASEDEPTNUMBER + "' and HUSEORGID ='" + HProdORGID + "'", "Gy_Department"); + string HPurchaseDeptID = dataSet.Tables[0].Rows.Count == 0 ? "0" : dataSet.Tables[0].Rows[0][0].ToString(); // 閲囪喘閮ㄩ棬 + + decimal HPURCHASEQTY = _item.FPURCHASEQTY; // 閲囪喘璁㈠崟鏁伴噺 + decimal HJoinQty = _item.FJOINQTY; // 閲囪喘璁㈠崟鍏宠仈鏁伴噺 + + oCN.RunProc("insert into JIT_Cg_PODemandPlanBillSub(HInterID,HEntryID,HLaterReason,HMaterID,HMaterName" + + ", HMaterModel, HUnitID, HErpClsID, HQty, HRemark" + + ", HPURCHASEORGID, HStatus, HFixleadTime, HDayPlanBillNo, HSourceInterID" + + ", HSourceEntryID, HSourceBillNo, HSourceBillType, HWorkShopID, HDayPlanDate" + + ", HRelationQty1, HPOOrderInterID, HPOOrderEntryID, HPOOrderBillNo, HPOOrderBillSEQ" + + ", HWWOrderInterID, HWWOrderEntryID, HWWOrderBillNo, HPurchaseDeptID, HCloseTypeSub" + + ", HCloseMan, HEntryCloseDate, HSendQty, HReciveQty, HCloseStatus" + + ", HRemoveQty, HSeOrderBillNo, HUnReciveQty, HPOOrderBillDate, HPOOrderBillDeliveryDate" + + ", HPOOrderBillRemark, HPOOrderBillNote)" + + $"values({HInterID}, {i}, '', {(HMaterID == null ? "0" : HMaterID)}, '{HMaterName}'" + + $", '{HMaterModel}', {HUnitID}, '{HErpClsID}', {HQty}, ''" + + $", {HPURCHASEORGIDSub}, '', {HFixleadTime}, '{HDayPlanBillNo}', {HSourceInterID}" + + $", {HSourceEntryID}, '{HSourceBillNo}', '{HSourceBillType}', {HWorkShopID}, '{HDayPlanDate}'" + + $", {HRelationQty}, {HPOOrderInterID},{HPOOrderEntryID}, '{HPOOrderBillNo}',0" + + $",0,0, '',{HPurchaseDeptID}, '0'" + + $", '','',0,0, '0'" + + $",0, '{HSeOrderBillNo}',0, '{HPOOrderBillDate}', '{HPOOrderBillDeliveryDate}'" + + $", '{HPOOrderBillRemark}', '{HPOOrderBillNote}')"); + + } + //model.Add("FEntity", Fentity); + //FinalyResult.Add(model); + // if ((tlmmm >= 20 || tlmmm == PODemandPlanList.Count) && (tlmmm % 20 == 0 || tlmmm == PODemandPlanList.Count)) + // { + // //LogHelper.Info("鎻愭枡璁″垝鏂板鎵归噺鎵ц锛岃褰曞惊鐜殑褰撳墠鏉℃暟" + tlmmm); + // JObject jsonRoot = new JObject() + // { + // ["Creator"] = "", + // ["NeedUpDateFields"] = new JArray(), + // ["NeedReturnFields"] = new JArray(), + // ["IsDeleteEntry"] = "false", + // ["SubSystemId"] = "", + // ["IsVerifyBaseDataField"] = "false", + // ["Model"] = FinalyResult + // }; + // CloudClient cloudClient = new CloudClient("http://localhost//k3cloud/"); + // var result = cloudClient.BatchSave("paez_PODemandPlan", jsonRoot.ToString()); + // JObject saveObj = JObject.Parse(result); + // string saveIsSuc = saveObj["Result"]["ResponseStatus"]["IsSuccess"].ToString().ToUpper(); + // if (saveIsSuc != "TRUE") + // { + // //LogHelper.Error(jsonRoot.ToString()); + // } + // FinalyResult = new JArray(); + // } + // tlmmm++; + } + + if (tlmmm == PODemandPlanList.Count && tlmmm != 0) + { + oCN.Commit(); + objJsonResult.code = "1"; + objJsonResult.count = 1; + objJsonResult.Message = "杩愮畻鎴愬姛!"; + objJsonResult.data = null; + return objJsonResult; + } + else + { + oCN.RollBack();//浜嬪姟鍥炴粴 + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = Error; + objJsonResult.data = null; + return objJsonResult; + } + + ////sw.Stop();//缁撴潫璁℃椂 + //////LogHelper.Info("鎻愭枡璁″垝鎵ц瀹屾垚锛岃繍琛屾�绘椂闀匡細" + sw.Elapsed); + //DBServiceHelper.ExecuteBatch(Context, sqlList); + + objJsonResult.code = "1"; + objJsonResult.count = 1; + objJsonResult.Message = "鎻愭枡杩愮畻鎴愬姛锛�"; + objJsonResult.data = null; + return objJsonResult; + } + catch (Exception e) + { + LogService.Write("鎿嶄綔澶辫触锛�" + e.Message.ToString()); + oCN.RollBack();//浜嬪姟鍥炴粴 + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "Exception锛�" + e.Message.ToString(); + objJsonResult.data = null; + return objJsonResult; + } + + } + + /// <summary> + /// 閫氳繃鐢熶骇鐢ㄦ枡娓呭崟 绠楃己鏂欐儏鍐� + /// </summary> + /// <returns></returns> + public object JIT_PPBOM(string fProWorkShopId,int? fPrdOrgId,string user,string sqlName) { + + try + { + Stopwatch sw = new Stopwatch(); + sw.Start();//寮�濮嬭鏃� + //鎻愭枡璁″垝棰勫鐞� 娓呯悊鎻愭枡璁″垝鍗曟暟鎹� 鏇存柊閲囪喘璁㈠崟鎻愭枡璁″垝鏁伴噺 骞朵笖鏌ヨ鍑洪渶瑕佽繘琛岃繍绠楃殑鏁版嵁 + + oCN.BeginTran(); //寮�濮嬩簨鍔� + + ds = oCN.RunProcReturn($"exec h_p_PROC_JIT_TLPLANYCL '{fProWorkShopId}','{fPrdOrgId}'", "h_p_PROC_JIT_TLPLANYCL"); + List<DayPlanPpbom> DayPlanPpbom = ds.ToModelList<DayPlanPpbom>(); + + if (DayPlanPpbom.Count == 0) + { + oCN.RollBack();//鍥炴粴浜嬪姟 + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "鏃犳暟鎹繍绠�!"; + objJsonResult.data = null; + return objJsonResult; + } + + //閲囪喘璁㈠崟鏁版嵁 锛堝墿浣欐敹鏂欐暟閲忥級 + + //t2.FXQD t2.FSTOCKINQTY,t2.FReceiveQty 鏈湴娌℃湁杩欎簺瀛楁 + string sql = string.Format(@" +select * from h_v_jit_POOrderList where FQTY>0 and FCloseStatus in('A') +and FMRPCLOSESTATUS in('A') and FBillTypeID in('83d822ca3e374b4ab01e5dd46a0062bd','6d01d059713d42a28bb976c90a121142') and FStockOrgId = '{0}'", fPrdOrgId); + + ds = oCN.RunProcReturn(sql, "h_v_jit_POOrderList"); + + if (ds.Tables[0].Rows.Count == 0) + { + oCN.RollBack();//鍥炴粴浜嬪姟 + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "鏌ユ棤閲囪喘璁㈠崟鏁版嵁!"; + objJsonResult.data = null; + return objJsonResult; + } + + List<PurchaseInventory> PurchaseInventory = ds.ToModelList<PurchaseInventory>(); + //鐗╂枡+搴撳瓨缁勭粐鍒嗙被 + var MaterialIDList = DayPlanPpbom.GroupBy(p => new { p.FMATERIALID, p.FStockOrgId }).Select(x => new PODemandPlanTemp { FMATERIALID = x.Key.FMATERIALID, FStockOrgId = x.Key.FStockOrgId }).ToList(); + + //鎻愭枡璁″垝鏁版嵁闆嗕复鏃跺瓨鍌ㄩ泦鍚� + List<PODemandPlanTemp> PODemandPlanTemp = new List<PODemandPlanTemp>(); + //sql闆嗗悎 鏇存柊閲囪喘璁㈠崟鍗犵敤鐨勬彁鏂欒鍒掓暟閲� + List<string> sqlList = new List<string>(); + + foreach (var item in MaterialIDList) + { + //this.View.Session["ProcessRateValue"] = Convert.ToInt32((Convert.ToDecimal(75) / MaterialIDList.Count) * i); + //褰撳墠鐗╂枡鍜屽簱瀛樼粍缁囧搴旂殑闇�杩涜鎻愭枡璁″垝鐨勬暟鎹� + List<DayPlanPpbom> _DayPlanPpbom = DayPlanPpbom.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId).ToList(); + decimal NeedQty = 0; + foreach (var _item in _DayPlanPpbom) + { + //鏌ヨ鏈夋病鏈夊彲浠ョ敤浜庢彁鏂欑殑閲囪喘璁㈠崟鏁版嵁 + var _PurchaseInventory = PurchaseInventory.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId && x.FQTY > 0).OrderBy(x => x.FENTRYID).ToList(); + if (_PurchaseInventory.Count == 0) + { + //鏃犻噰璐鍗曠洿鎺ヤ笅涓�涓墿鏂� + sql = $"INSERT INTO JIT_TLPLANERROR(HROGID,HUSERID,HWORKSHOPID,HDAYPLANID,HDAYPLANENTRYID,HMATERIALID,HQTY,HTYPE) VALUES({fPrdOrgId},{user},{fProWorkShopId},{_item.FID},{_item.FENTRYID},{_item.FMATERIALID},{_item.NeedQty},0) "; + sqlList.Add(sql); + break; + } + //闇�姹傛暟閲� + NeedQty = _item.NeedQty; + //澧炲姞涓�涓攢鍞鍗曞彿鍖归厤鐨勯�昏緫 浼樺厛寰幆 + var PurchaseInventoryBySalOrder = _PurchaseInventory.Where(x => x.FXQD == _item.FXQD).OrderBy(x => x.FENTRYID).ToList(); + if (PurchaseInventoryBySalOrder.Count > 0) + { + foreach (var Purchase in PurchaseInventoryBySalOrder) + { + double _FFIXLEADTIME = Purchase.FFIXLEADTIME;//鎻愬墠鏈� + DateTime _DATE = Convert.ToDateTime(_item.FHMASTERDATE).AddDays(-_FFIXLEADTIME); + if (Purchase.FQTY >= NeedQty) + { + PODemandPlanTemp.Add(new PODemandPlanTemp + { + FID = _item.FID, + FHMASTERDATE = _DATE, + FQty = NeedQty, + FBILLNO = _item.FBILLNO, + FENTRYID = _item.FENTRYID, + FMATERIALID = _item.FMATERIALID, + FNumber = _item.FNumber, + OLDDATE = _item.FHMASTERDATE, + FFIXLEADTIME = _FFIXLEADTIME, + FErpClsID = _item.FErpClsID, + FWORKSHOPNUMBER = _item.FWORKSHOPNUMBER, + FDAYPLANBILLNO = _item.FDAYPLANBILLNO, + + PurchseFentryID = Purchase.FENTRYID, + FSUPPLIERID = Purchase.FSUPPLIERID, + PurchseFNUMBER = Purchase.FNUMBER, + PurchseFBillNo = Purchase.FBillNo, + PurchseFqty = Purchase.FQTY, + FStockOrgId = Purchase.FStockOrgId, //閲囪喘缁勭粐 + FORGNumber = Purchase.FORGNumber, + FPURCHASEDEPTNUMBER = Purchase.FPURCHASEDEPTNUMBER, + + FXQD = _item.FXQD, + FCREATORID = Purchase.FCREATORID, + FName = Purchase.FName, + FDate = Purchase.FDate, + FDeliveryDate = Purchase.FDeliveryDate, + F_QIMB_NOTE = Purchase.F_QIMB_NOTE, + FNOTE = Purchase.FNOTE, + FPURCHASEQTY = Purchase.FPURCHASEQTY, + FJOINQTY = Purchase.FJOINQTY + + }); + //鎵i櫎鏃ヨ鍒掓槑缁嗗凡琚垎閰嶇殑鏁伴噺 + _item.NeedQty = 0; + //鎵i櫎褰撳墠琛屽搴旈噰璐鍗曟暟閲� + Purchase.FQTY -= NeedQty; + //鏇存柊閲囪喘璁㈠崟 + //sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount =isnull(FPODemandPlanCount,0)+ '{NeedQty}' where FENTRYID = {Purchase.FENTRYID}"); + //闇�姹傛暟閲忓彉涓�0 + NeedQty = 0; + break; + } + else//閲囪喘璁㈠崟鏁版嵁涓嶈兘婊¤冻璁㈠崟鎵�闇�鏁伴噺 + { + //閲囪喘璁㈠崟鏁伴噺 + decimal _NeedQty = Purchase.FQTY; + PODemandPlanTemp.Add(new PODemandPlanTemp + { + FID = _item.FID, + FHMASTERDATE = _DATE, + FQty = _NeedQty, + FBILLNO = _item.FBILLNO, + FENTRYID = _item.FENTRYID, + FMATERIALID = _item.FMATERIALID, + FNumber = _item.FNumber, + OLDDATE = _item.FHMASTERDATE, + FFIXLEADTIME = _FFIXLEADTIME, + FErpClsID = _item.FErpClsID, + FWORKSHOPNUMBER = _item.FWORKSHOPNUMBER, + FDAYPLANBILLNO = _item.FDAYPLANBILLNO, + + PurchseFentryID = Purchase.FENTRYID, + FSUPPLIERID = Purchase.FSUPPLIERID, + PurchseFNUMBER = Purchase.FNUMBER, + PurchseFBillNo = Purchase.FBillNo, + PurchseFqty = Purchase.FQTY, + FStockOrgId = Purchase.FStockOrgId, //閲囪喘缁勭粐 + FORGNumber = Purchase.FORGNumber, + FPURCHASEDEPTNUMBER = Purchase.FPURCHASEDEPTNUMBER, + + FXQD = _item.FXQD, + FCREATORID = Purchase.FCREATORID, + FName = Purchase.FName, + FDate = Purchase.FDate, + FDeliveryDate = Purchase.FDeliveryDate, + F_QIMB_NOTE = Purchase.F_QIMB_NOTE, + FNOTE = Purchase.FNOTE, + FPURCHASEQTY = Purchase.FPURCHASEQTY, + FJOINQTY = Purchase.FJOINQTY + }); + //鏇存柊閲囪喘璁㈠崟 + //sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount = isnull(FPODemandPlanCount,0)+ '{Purchase.FQTY}' where FENTRYID = {Purchase.FENTRYID}"); + //鏇存柊璁㈠崟闇�姹傛暟閲� + NeedQty = NeedQty - Purchase.FQTY; + //鎵i櫎鏃ヨ鍒掓槑缁嗗凡琚垎閰嶇殑鏁伴噺 + _item.NeedQty -= _NeedQty; + //鎵i櫎褰撳墠琛屽搴旈噰璐鍗曟暟閲� + Purchase.FQTY = 0; + } + } + } + if (NeedQty == 0) + continue; + var PurchaseInventoryElse = _PurchaseInventory.Where(x => x.FXQD != _item.FXQD).OrderBy(x => x.FENTRYID).ToList(); + foreach (var Purchase in PurchaseInventoryElse) + { + double _FFIXLEADTIME = Purchase.FFIXLEADTIME;//鎻愬墠鏈� + DateTime _DATE = Convert.ToDateTime(_item.FHMASTERDATE).AddDays(-_FFIXLEADTIME); + if (Purchase.FQTY >= NeedQty) + { + PODemandPlanTemp.Add(new PODemandPlanTemp + { + FID = _item.FID, + FHMASTERDATE = _DATE, + FQty = _item.NeedQty, + FBILLNO = _item.FBILLNO, + FENTRYID = _item.FENTRYID, + FMATERIALID = _item.FMATERIALID, + FNumber = _item.FNumber, + OLDDATE = _item.FHMASTERDATE, + FFIXLEADTIME = _FFIXLEADTIME, + FErpClsID = _item.FErpClsID, + FWORKSHOPNUMBER = _item.FWORKSHOPNUMBER, + FDAYPLANBILLNO = _item.FDAYPLANBILLNO, + + PurchseFentryID = Purchase.FENTRYID, + FSUPPLIERID = Purchase.FSUPPLIERID, + PurchseFNUMBER = Purchase.FNUMBER, + PurchseFBillNo = Purchase.FBillNo, + PurchseFqty = Purchase.FQTY, + FStockOrgId = Purchase.FStockOrgId, //閲囪喘缁勭粐 + FORGNumber = Purchase.FORGNumber, + FPURCHASEDEPTNUMBER = Purchase.FPURCHASEDEPTNUMBER, + + FXQD = _item.FXQD, + FCREATORID = Purchase.FCREATORID, + FName = Purchase.FName, + FDate = Purchase.FDate, + FDeliveryDate = Purchase.FDeliveryDate, + F_QIMB_NOTE = Purchase.F_QIMB_NOTE, + FNOTE = Purchase.FNOTE, + FPURCHASEQTY = Purchase.FPURCHASEQTY, + FJOINQTY = Purchase.FJOINQTY + }); + //鏇存柊閲囪喘璁㈠崟 + //sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount =isnull(FPODemandPlanCount,0)+ '{NeedQty}' where FENTRYID = {Purchase.FENTRYID}"); + //鎵i櫎鏃ヨ鍒掓槑缁嗗凡琚垎閰嶇殑鏁伴噺 + _item.NeedQty = 0; + //鎵i櫎褰撳墠琛屽搴旈噰璐鍗曟暟閲� + Purchase.FQTY -= NeedQty; + //闇�姹傛暟閲忓彉涓�0 + NeedQty = 0; + break; + } + else//閲囪喘璁㈠崟鏁版嵁涓嶈兘婊¤冻璁㈠崟鎵�闇�鏁伴噺 + { + //鏇存柊鎬婚渶姹傛暟閲� + NeedQty = NeedQty - Purchase.FQTY; + //閲囪喘璁㈠崟鏁伴噺 + decimal _NeedQty = Purchase.FQTY; + PODemandPlanTemp.Add(new PODemandPlanTemp + { + FID = _item.FID, + FHMASTERDATE = _DATE, + FQty = _NeedQty, + FBILLNO = _item.FBILLNO, + FENTRYID = _item.FENTRYID, + FMATERIALID = _item.FMATERIALID, + FNumber = _item.FNumber, + OLDDATE = _item.FHMASTERDATE, + FFIXLEADTIME = _FFIXLEADTIME, + FErpClsID = _item.FErpClsID, + FWORKSHOPNUMBER = _item.FWORKSHOPNUMBER, + FDAYPLANBILLNO = _item.FDAYPLANBILLNO, + + PurchseFentryID = Purchase.FENTRYID, + FSUPPLIERID = Purchase.FSUPPLIERID, + PurchseFNUMBER = Purchase.FNUMBER, + PurchseFBillNo = Purchase.FBillNo, + PurchseFqty = Purchase.FQTY, + FStockOrgId = Purchase.FStockOrgId, //閲囪喘缁勭粐 + FORGNumber = Purchase.FORGNumber, + FPURCHASEDEPTNUMBER = Purchase.FPURCHASEDEPTNUMBER, + + FXQD = _item.FXQD, + FCREATORID = Purchase.FCREATORID, + FName = Purchase.FName, + FDate = Purchase.FDate, + FDeliveryDate = Purchase.FDeliveryDate, + F_QIMB_NOTE = Purchase.F_QIMB_NOTE, + FNOTE = Purchase.FNOTE, + FPURCHASEQTY = Purchase.FPURCHASEQTY, + FJOINQTY = Purchase.FJOINQTY + }); + //鏇存柊閲囪喘璁㈠崟 + //sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount = isnull(FPODemandPlanCount,0)+ '{Purchase.FQTY}' where FENTRYID = {Purchase.FENTRYID}"); + //鎵i櫎鏃ヨ鍒掓槑缁嗗凡琚垎閰嶇殑鏁伴噺 + _item.NeedQty -= _NeedQty; + //鎵i櫎褰撳墠琛屽搴旈噰璐鍗曟暟閲� + Purchase.FQTY = 0; + } + } + if (NeedQty > 0) + { + sql = $"INSERT INTO JIT_TLPLANERROR(HROGID,HUSERID,HWORKSHOPID,HDAYPLANID,HDAYPLANENTRYID,HMATERIALID,HQTY,HTYPE,HERRORTYPE) VALUES({fPrdOrgId},{user},{fProWorkShopId},{_item.FID},{_item.FENTRYID},{_item.FMATERIALID},{NeedQty},0,1) "; + sqlList.Add(sql); + } + } + } + + //渚涘簲鍟嗭紝鎻愭枡鏃ユ湡锛岀敓浜ц溅闂达紝閲囪喘鍛� 鍒嗙粍 + var PODemandPlanList = PODemandPlanTemp.GroupBy(p => new { p.PurchseFNUMBER, p.FHMASTERDATE, p.FWORKSHOPNUMBER, p.FCREATORID }).Select(x => new PODemandPlanTemp { PurchseFNUMBER = x.Key.PurchseFNUMBER, FHMASTERDATE = x.Key.FHMASTERDATE, FWORKSHOPNUMBER = x.Key.FWORKSHOPNUMBER, FCREATORID = x.Key.FCREATORID }).ToList(); + + LogService.Write("鎻愭枡璁″垝閲嶇畻 锛屾暟鎹噯澶囧畬鎴愶紝淇濆瓨鍒癕odel瀹炰綋 鐢ㄦ椂锛�" + sw.Elapsed + "鎬昏鏁帮細" + PODemandPlanTemp.Count); + + int tlmmm = 0; + JArray FinalyResult = new JArray(); + foreach (var item in PODemandPlanList) + { + tlmmm++; + + DateTime date = item.FHMASTERDATE; + long HSettleCurrId = 1;//璐у竵 榛樿鏈湴浜烘皯甯� + + var dataSup = oCN.RunProcReturn(@"select * from Gy_Supplier p + inner join " + sqlName + @"..t_BD_Supplier fp on p.HNumber=fp.FNUMBER and p.HUSEORGID=fp.FUSEORGID + where FNUMBER='" + item.PurchseFNUMBER + "' and HUSEORGID ='" + fPrdOrgId + "'", "Gy_Supplier"); + long HSupplierID = dataSup.Tables[0].Rows.Count == 0 ? 0 : long.Parse(dataSup.Tables[0].Rows[0]["HItemID"].ToString()); //渚涘簲鍟� + + var dataUser = oCN.RunProcReturn("select Czymc from gy_czygl where Czybm = '" + user + "'", "gy_czygl"); + string HMaker = dataUser.Tables[0].Rows.Count == 0 ? "" : dataUser.Tables[0].Rows[0][0].ToString();//鍒跺崟浜� + string HUpDater = dataUser.Tables[0].Rows.Count == 0 ? "" : dataUser.Tables[0].Rows[0][0].ToString();//淇敼浜� + + var dataOrg = oCN.RunProcReturn(@"select HItemID from Xt_ORGANIZATIONS o + inner join " + sqlName + @"..T_ORG_ORGANIZATIONS fo on o.HNumber=fo.FNUMBER + where FNUMBER='" + PODemandPlanTemp[0].FORGNumber + "' and HItemID ='" + fPrdOrgId + "'", "Xt_ORGANIZATIONS"); + long HPURCHASEORGID = dataOrg.Tables[0].Rows.Count == 0 ? 0 : long.Parse(dataOrg.Tables[0].Rows[0]["HItemID"].ToString()); //閲囪喘缁勭粐 + + string PurchseFNUMBER = item.PurchseFNUMBER; + string FWorkshopNumber = item.FWORKSHOPNUMBER; + string FCreatorID = item.FCREATORID; + + var HInterID = DBUtility.ClsPub.CreateBillID("4608", ref DBUtility.ClsPub.sExeReturnInfo); + var HBillNo = DBUtility.ClsPub.CreateBillCode("4608", ref DBUtility.ClsPub.sExeReturnInfo, true); + //涓昏〃 + oCN.RunProc("insert into JIT_Cg_PODemandPlanBillMain(HInterID,HBillNo,HYear,HPeriod,HBillType" + + ",HBillSubType,HDate,HBillStatus,HMaker,HMakeDate" + + ",HSubORGID ,HAddress,HPURCHASEORGID,HSupplierID ,HSettleCurrId" + + ",HRemark,HExplanation,HUpDater,HUpDateDate)" + + $"values({HInterID}, '{HBillNo}', {DateTime.Now.Year}, {DateTime.Now.Month}, '4608'" + + $", '4608','{date}',1, '{HMaker}',GETDATE()," + + $"{HPURCHASEORGID},'',{HPURCHASEORGID}, {HSupplierID}, {HSettleCurrId}" + + $",'','','{HUpDater}',getdate())"); + + List<PODemandPlanTemp> _PODemandPlanList = PODemandPlanTemp.Where(x => x.FHMASTERDATE == date && x.PurchseFNUMBER == PurchseFNUMBER && x.FWORKSHOPNUMBER == FWorkshopNumber && x.FCREATORID == FCreatorID).ToList(); + int i = 0; + foreach (var _item in _PODemandPlanList) + { + i++; + + var dataSet = oCN.RunProcReturn(@"select m.* from Gy_Material m + inner join " + sqlName + @"..T_BD_MATERIAL fm on m.HNumber = fm.FNUMBER and m.HUSEORGID=fm.FUSEORGID + where FNUMBER='" + _item.FNumber + "' and HUSEORGID ='" + fPrdOrgId + "'", "Gy_Material"); + string HMaterID = "0"; //鐗╂枡 + string HMaterModel = ""; //鐗╂枡浠g爜 + string HMaterName = ""; //鐗╂枡鍚嶇О + if (dataSet.Tables[0].Rows.Count != 0) + { + HMaterID = dataSet.Tables[0].Rows[0]["HItemID"].ToString(); //鐗╂枡 + HMaterModel = dataSet.Tables[0].Rows[0]["HNumber"].ToString(); //鐗╂枡浠g爜 + HMaterName = dataSet.Tables[0].Rows[0]["HName"].ToString(); //鐗╂枡鍚嶇О + } + + decimal HQty = _item.FQty; //鏁伴噺 + long HSourceInterID = _item.FID; //鏃ヨ鍒掑伐鍗旻ID + long HSourceEntryID = _item.FENTRYID;//鏃ヨ鍒掑伐鍗旻ENTRYID + string HSourceBillNo = _item.FBILLNO; //鐢熶骇璁㈠崟鍙� + string HSourceBillType = ""; //鏃ヨ鍒掑伐鍗曠被鍨� + DateTime HDayPlanDate = _item.OLDDATE; // 宸ュ崟鐢熶骇鏃ユ湡 + decimal HRelationQty = _item.PurchseFqty; // 鍏宠仈鏁伴噺 + double HFixleadTime = _item.FFIXLEADTIME; // 鎻愬墠鏈� + + dataOrg = oCN.RunProcReturn(@"select HItemID from Xt_ORGANIZATIONS o + inner join " + sqlName + @"..T_ORG_ORGANIZATIONS fo on o.HNumber=fo.FNUMBER + where FNUMBER='" + _item.FORGNumber + "' and HItemID ='" + fPrdOrgId + "'", "Xt_ORGANIZATIONS"); + long HPURCHASEORGIDSub = dataOrg.Tables[0].Rows.Count == 0 ? 0 : long.Parse(dataOrg.Tables[0].Rows[0]["HItemID"].ToString()); // 閲囪喘缁勭粐 + long HPOOrderInterID = _item.PurchseFID; // 閲囪喘璁㈠崟鍐呯爜 + long HPOOrderEntryID = _item.PurchseFentryID; // 閲囪喘璁㈠崟瀛愬唴鐮� + string HPOOrderBillNo = _item.PurchseFBillNo; // 閲囪喘璁㈠崟鍙� + string HErpClsID = _item.FErpClsID; // 鐗╂枡灞炴�� + long HUnitID = 10101; // 璁¢噺鍗曚綅 鍏堟寜鐓ф湰鍦版潵 榛樿 Pcs + string HSeOrderBillNo = _item.FXQD; // 閿�鍞鍗曞彿 闇�姹傚崟鍙� + string HOrderEmpID = _item.FCREATORID; // 閲囪喘鍛� + DateTime HPOOrderBillDate = _item.FDate; // 閲囪喘璁㈠崟鍗曟嵁鏃ユ湡 + DateTime HPOOrderBillDeliveryDate = _item.FDeliveryDate; // 閲囪喘璁㈠崟浜よ揣鏃ユ湡 + string HPOOrderBillRemark = _item.F_QIMB_NOTE; // 閲囪喘璁㈠崟鎽樿 + string HPOOrderBillNote = _item.FNOTE; // 閲囪喘璁㈠崟琛ㄤ綋澶囨敞 + string HDayPlanBillNo = _item.FDAYPLANBILLNO; // 鏃ヨ鍒掑伐鍗曞彿 + + dataSet = oCN.RunProcReturn(@"select HItemID from Gy_Department d + inner join " + sqlName + @"..T_BD_DEPARTMENT fd on d.HNumber = fd.FNUMBER + where FNUMBER='" + _item.FWORKSHOPNUMBER + "' and HUSEORGID ='" + fPrdOrgId + "'", "Gy_Department"); + string HWorkShopID = dataSet.Tables[0].Rows.Count == 0 ? "0" : dataSet.Tables[0].Rows[0][0].ToString(); // 鐢熶骇杞﹂棿 + + dataSet = oCN.RunProcReturn(@"select HItemID from Gy_Department d + inner join " + sqlName + @"..T_BD_DEPARTMENT fd on d.HNumber = fd.FNUMBER + where FNUMBER='" + _item.FPURCHASEDEPTNUMBER + "' and HUSEORGID ='" + fPrdOrgId + "'", "Gy_Department"); + string HPurchaseDeptID = dataSet.Tables[0].Rows.Count == 0 ? "0" : dataSet.Tables[0].Rows[0][0].ToString(); // 閲囪喘閮ㄩ棬 + + decimal HPURCHASEQTY = _item.FPURCHASEQTY; // 閲囪喘璁㈠崟鏁伴噺 + decimal HJoinQty = _item.FJOINQTY; // 閲囪喘璁㈠崟鍏宠仈鏁伴噺 + + oCN.RunProc("insert into JIT_Cg_PODemandPlanBillSub(HInterID,HEntryID,HLaterReason,HMaterID,HMaterName" + + ", HMaterModel, HUnitID, HErpClsID, HQty, HRemark" + + ", HPURCHASEORGID, HStatus, HFixleadTime, HDayPlanBillNo, HSourceInterID" + + ", HSourceEntryID, HSourceBillNo, HSourceBillType, HWorkShopID, HDayPlanDate" + + ", HRelationQty1, HPOOrderInterID, HPOOrderEntryID, HPOOrderBillNo, HPOOrderBillSEQ" + + ", HWWOrderInterID, HWWOrderEntryID, HWWOrderBillNo, HPurchaseDeptID, HCloseTypeSub" + + ", HCloseMan, HEntryCloseDate, HSendQty, HReciveQty, HCloseStatus" + + ", HRemoveQty, HSeOrderBillNo, HUnReciveQty, HPOOrderBillDate, HPOOrderBillDeliveryDate" + + ", HPOOrderBillRemark, HPOOrderBillNote)" + + $"values({HInterID}, {i}, '', {(HMaterID == null ? "0" : HMaterID)}, '{HMaterName}'" + + $", '{HMaterModel}', {HUnitID}, '{HErpClsID}', {HQty}, ''" + + $", {HPURCHASEORGIDSub}, '', {HFixleadTime}, '{HDayPlanBillNo}', {HSourceInterID}" + + $", {HSourceEntryID}, '{HSourceBillNo}', '{HSourceBillType}', {HWorkShopID}, '{HDayPlanDate}'" + + $", {HRelationQty}, {HPOOrderInterID},{HPOOrderEntryID}, '{HPOOrderBillNo}',0" + + $",0,0, '',{HPurchaseDeptID}, '0'" + + $", '','',0,0, '0'" + + $",0, '{HSeOrderBillNo}',0, '{HPOOrderBillDate}', '{HPOOrderBillDeliveryDate}'" + + $", '{HPOOrderBillRemark}', '{HPOOrderBillNote}')"); + } + } + + if (tlmmm == PODemandPlanList.Count) + { + oCN.Commit(); + objJsonResult.code = "1"; + objJsonResult.count = 1; + objJsonResult.Message = "杩愮畻鎴愬姛!"; + objJsonResult.data = null; + return objJsonResult; + } + else + { + oCN.RollBack();//浜嬪姟鍥炴粴 + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "杩愮畻澶辫触!"; + objJsonResult.data = null; + return objJsonResult; + } + } + catch (Exception e) + { + LogService.Write("鎿嶄綔澶辫触锛�" + e.Message.ToString()); + oCN.RollBack();//浜嬪姟鍥炴粴 + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "Exception锛�" + e.Message.ToString(); + objJsonResult.data = null; + return objJsonResult; + } + } + #endregion + + #region 鐢熶骇鏃ヨ鍒掑钩鍙� 閿佸畾 + [Route("JIT_DayPlanPlatFormBill/JIT_DayPlanPlatFormBillHLockedDay")] + [HttpGet] + public object JIT_DayPlanPlatFormBillHLockedDay(int HLockedDay,int HWorkShopID) + { + try + { + oCN.RunProc("update b set HLockedSub=0 from Sc_WorkBillSortBillMain a join Sc_WorkBillSortBillSub b on a.HInterID = b.HInterID " + + $" where a.HWorkShopID={HWorkShopID}"); + + oCN.RunProc("update b set HLockedSub=1 from Sc_WorkBillSortBillMain a join Sc_WorkBillSortBillSub b on a.HInterID = b.HInterID " + + $" where HMasterDate between DATEADD(day, -1, getdate()) " + + $"and DATEADD(day,{(HLockedDay - 1)},getdate()) and a.HWorkShopID={HWorkShopID}"); + + objJsonResult.code = "1"; + objJsonResult.count = 1; + objJsonResult.Message = "Sucess锛�"; + objJsonResult.data = null; + return objJsonResult; + } + catch (Exception e) + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "Exception锛�" + e.ToString(); + objJsonResult.data = null; + return objJsonResult; + } + } + #endregion + + #region 鐢熶骇鏃ヨ鍒掑钩鍙� 瑙i攣 + [Route("JIT_DayPlanPlatFormBill/JIT_DayPlanPlatFormBillHUnlockDay")] + [HttpGet] + public object JIT_DayPlanPlatFormBillHUnlockDay(int HWorkShopID) + { + try + { + oCN.RunProc("update b set HLockedSub=0 from Sc_WorkBillSortBillMain a join Sc_WorkBillSortBillSub b on a.HInterID = b.HInterID " + + $" where a.HWorkShopID={HWorkShopID}"); + + objJsonResult.code = "1"; + objJsonResult.count = 1; + objJsonResult.Message = "Sucess锛�"; + objJsonResult.data = null; + return objJsonResult; + } + catch (Exception e) + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "Exception锛�" + e.ToString(); + objJsonResult.data = null; + return objJsonResult; + } + } + #endregion + + #region 鐢熶骇鏃ヨ鍒掑钩鍙� 鐢熶骇璁㈠崟鏌ヨ + [Route("JIT_DayPlanPlatFormBill/JIT_ICMOBillList")] + [HttpGet] + public object JIT_ICMOBillList(string hmainid) + { + try + { + var list = hmainid.Split(','); + List<DataTable> listdt = new List<DataTable>(); + DataTable dtable = new DataTable("dt"); + for (int i = 0; i < list.Length; i++) + { + var listEvery = list[i].Split('_'); + + ds = oCN.RunProcReturn($"exec h_p_ICMOBillList_PrimarySubTable '{listEvery[0]}','{listEvery[1]}'", "h_p_ICMOBillList_PrimarySubTable"); + + var dt = oCN.RunProcReturn($"select * from h_v_JIT_Sc_WorkBillSortBillList where 婧愬崟涓诲唴鐮� in({ds.Tables[0].Rows[0]["婧愬崟涓诲唴鐮�"].ToString()}) and 婧愬崟瀛愬唴鐮� in({ds.Tables[0].Rows[0]["婧愬崟瀛愬唴鐮�"].ToString()})", "h_v_JIT_Sc_WorkBillSortBillList"); + if (dt.Tables[0].Rows.Count > 0) + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "鐢熶骇鏄庣粏琛岄噸澶�,閲嶅鐨勭敓浜ц鍗曞彿:" + ds.Tables[0].Rows[i]["鐢熶骇璁㈠崟鍙�"].ToString() + ",鏄庣粏琛屽彿:" + ds.Tables[0].Rows[i]["鐢熶骇璁㈠崟鏄庣粏琛屽彿"].ToString(); + objJsonResult.data = null; + return objJsonResult; + } + if (i == 0) + { + //娣诲姞鍒楀悕 + for (int j = 0; j < ds.Tables[0].Columns.Count; j++) + { + dtable.Columns.Add(ds.Tables[0].Columns[j].ToString()); + } + } + listdt.Add(ds.Tables[0]); + } + + //鑾峰彇闆嗗悎鏁版嵁 + for (int i = 0; i < listdt.Count; i++) + { + DataRow row = dtable.NewRow(); + for (int j = 0; j < listdt[i].Columns.Count; j++) + { + if (listdt[i].Columns[j].ColumnName == "璁″垝鏁伴噺") + { + row[j] = double.Parse(listdt[i].Rows[0][j].ToString()).ToString(); + } + else + { + row[j] = listdt[i].Rows[0][j].ToString(); + } + } + dtable.Rows.Add(row); + } + + //娣诲姞鍔ㄦ�佹棩鏈� + for (int j = 1; j <= 31; j++) + { + dtable.Columns.Add(DateTime.Now.AddDays(j - 1).ToString("yyyy-MM-dd"), typeof(Int32)); + } + + objJsonResult.code = "1"; + objJsonResult.count = 1; + objJsonResult.Message = "Sucess锛�"; + objJsonResult.data = dtable; + return objJsonResult; + } + catch (Exception e) + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "Exception锛�" + e.ToString(); + objJsonResult.data = null; + return objJsonResult; + } + } + #endregion + } } \ No newline at end of file -- Gitblit v1.9.1