using System; using System.Collections.Generic; using System.Data; using System.Linq; using System.Web; using System.Web.Http; using WebAPI.Models; using Newtonsoft.Json; using Newtonsoft.Json.Linq; using System.Diagnostics; using System.Threading; using System.Globalization; namespace WebAPI.Controllers.SCGL.日计划管理 { public class JIT_DayPlanPlatFormBillController : ApiController { List 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) { try { //查看权限 if (!DBUtility.ClsPub.Security_Log("Sc_WorkBillSortBill_Query", 1, false, user)) { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = "无查看权限!"; objJsonResult.data = null; return objJsonResult; } omdelMian = JsonConvert.DeserializeObject(sWhere); 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}" + $",'{omdelMian.HMastersDate}','{omdelMian.sWheres}'", "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; } } /// /// 根据ID查询 齐套状态 和 锁定状态 /// /// /// /// [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; 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; } } /// /// 根据点击行标题时间查询缺料分析 /// /// /// /// [Route("JIT_DayPlanPlatFormBill/JIT_DayPlanPlatFormBillHDateTimeList")] [HttpGet] public object JIT_DayPlanPlatFormBillHDateTimeList(string sWhere) { try { MaterialShorAnalysis Report = JsonConvert.DeserializeObject(sWhere); ds = oCN.RunProcReturn($"exec h_p_JIT_MaterialShorAnalysisReportList {Report.HORGID},'{Report.HBEGINDATE}','{Report.HENDDATE}' ", "h_p_JIT_PODemandPlanBill_ReportList"); objJsonResult.code = "1"; objJsonResult.count = 1; objJsonResult.Message = "Sucess!"; objJsonResult.data = ds.Tables[0]; //objJsonResult.list = columnNameList; 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_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 { Stopwatch sw = new Stopwatch();//计时器 sw.Start();//开始计时 if (!DBUtility.ClsPub.Security_Log("Sc_WorkBillSortBill_Edit", 1, false, user)) { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = "无保存权限!"; objJsonResult.data = null; return objJsonResult; } LogService.CustomWriteLog("1:"+msg2, DateTime.Now.ToString("yyyy-MM-dd")); //JSON序列化转换字典集合 List> list = new List>(); List jb = JsonConvert.DeserializeObject>(msg2); foreach (JObject item in jb) { Dictionary dic = new Dictionary(); foreach (var itm in item.Properties()) { dic.Add(itm.Name, itm.Value.ToString()); } list.Add(dic); } LogService.CustomWriteLog("2:", DateTime.Now.ToString("yyyy-MM-dd")); int TrueCount = 0, SumCount = 0; LogService.CustomWriteLog("list.Count:"+ list.Count, DateTime.Now.ToString("yyyy-MM-dd")); string sReturn = ""; oSystemParameter.ShowBill(ref sReturn); 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() == "") { LogService.CustomWriteLog("2.01:" + i, DateTime.Now.ToString("yyyy-MM-dd")); 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().Replace("'", "''"); 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 HPlanEndDate = 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(); var HEmpID = list[i]["HEmpID"].ToString(); var HWorkQty = list[i]["小时产能"].ToString(); var HSourceName = list[i]["生产资源"].ToString(); var HWorkQty_ProdLine = list[i]["产线总产能"].ToString(); LogService.CustomWriteLog("2.05:" + i, DateTime.Now.ToString("yyyy-MM-dd")); if (oSystemParameter.omodel.WMS_CampanyName != "添康科技") //系统参数 客户定制化名称 空白为通用 { if (HSourceID == "" || HSourceID == "0") { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = $"第{i + 1}行生产资源不能为空!"; objJsonResult.data = null; return objJsonResult; } } ds = oCN.RunProcReturn($"select HInterID,HICMOBillNo from Sc_WorkBillSortBillMain with(nolock) where HMainSourceInterID={HMainSourceInterID}" + $" and HMainSourceEntryID={HMainSourceEntryID} and HICMOBillNo='{HICMOBillNo}' and HICMOEntrySEQ={HICMOEntrySEQ} and HSourceID={HSourceID} and ISNULL(HDeleteMan,'')=''", "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);//获得一个新的id 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" + ",HICMOInterID,HICMOEntryID,HPlanEndDate,HEmpID,HWorkQty,HSourceName,HWorkQty_ProdLine)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}," + $"{HMainSourceInterID},{HMainSourceEntryID},'{HPlanEndDate}','{HEmpID}','{HWorkQty}','{HSourceName}','{HWorkQty_ProdLine}')"; //LogService.Write("sql:" + sql); //主表 oCN.RunProc(sql); } else { LogService.CustomWriteLog("2.0:" + i, DateTime.Now.ToString("yyyy-MM-dd")); HBillNo = list[i]["单据号"].ToString(); HInterID = int.Parse(list[i]["hmainid"].ToString()); 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(); var HWorkQty = list[i]["小时产能"].ToString(); var HProdTimes = list[i]["生产周期"].ToString(); var HReadyTimes = list[i]["开工余量"].ToString(); var HLastBeginDate = list[i]["最迟开工日期"].ToString(); var HLastEndDate = list[i]["最迟完工日期"].ToString(); var HOrderNeedQty = list[i]["订单需求数量"].ToString(); var HOrderCommitDate = list[i]["订单交货期"].ToString(); var HPlanEndDate = list[i]["计划结束日期"].ToString(); var HSplitQty = list[i]["拆单数量"].ToString(); var HSourceName = list[i]["生产资源"].ToString(); var HWorkQty_ProdLine = list[i]["产线总产能"].ToString(); var HOrderType = list[i]["订单类型"].ToString(); var HWorkShopID = list[i]["HWorkShopID"].ToString(); var HProdORGID = list[i]["HProdORGID"].ToString(); var HMaterID = list[i]["HMaterID"].ToString(); var HMaterName = list[i]["物料名称"].ToString(); var HMaterModel = list[i]["规格型号"].ToString().Replace("'", "''"); var HUnitID = list[i]["HUnitID"].ToString(); var HSeOrderBillQty = 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 HPlanQty = list[i]["计划数量"].ToString(); var HEmpID = list[i]["HEmpID"].ToString(); LogService.CustomWriteLog("2.1:"+i, DateTime.Now.ToString("yyyy-MM-dd")); if (oSystemParameter.omodel.WMS_CampanyName != "添康科技") //系统参数 客户定制化名称 空白为通用 { 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; } if (oSystemParameter.omodel.WMS_CampanyName == "添康科技") //系统参数 客户定制化名称 空白为通用 { //看有几台生产资源协同生产 string[] HSourceNameArr = HSourceName.Split(new char[]{'&'}); if (HSourceNameArr.Length >= 2) { for (int s = 0; s < HSourceNameArr.Length; s++) { if (s == 0) { ds = oCN.RunProcReturn("select HItemID from Gy_Source with(nolock) where HName = '" + HSourceNameArr[s] + "'", "Gy_Source"); var HSourceID_Child = ds.Tables[0].Rows[0]["HItemID"]; oCN.RunProc($"update Sc_WorkBillSortBillMain set HSourceID={(HSourceID_Child == "" ? 0.ToString() : HSourceID_Child)}" + $",HYX={HYX},HWorkQty={HWorkQty},HProdTimes={HProdTimes},HReadyTimes={HReadyTimes},HLastBeginDate='{HLastBeginDate}'" + $",HLastEndDate='{HLastEndDate}',HOrderNeedQty={HOrderNeedQty},HOrderCommitDate='{HOrderCommitDate}'" + $",HPlanEndDate='{HPlanEndDate}',HSplitQty={HSplitQty},HSourceName='{HSourceName}',HWorkQty_ProdLine={HWorkQty_ProdLine}" + $" where HInterID={list[i]["hmainid"].ToString()} and HBillNo='{list[i]["单据号"].ToString()}'"); } else { ds = oCN.RunProcReturn("select HItemID from Gy_Source with(nolock) where HName = '" + HSourceNameArr[s] + "'", "Gy_Source"); var HSourceID_Child = ds.Tables[0].Rows[0]["HItemID"]; //新增协同生产资源的排产记录 ds = oCN.RunProcReturn($"select HInterID,HICMOBillNo from Sc_WorkBillSortBillMain with(nolock) where HMainSourceInterID={HMainSourceInterID}" + $" and HMainSourceEntryID={HMainSourceEntryID} and HICMOBillNo='{HICMOBillNo}' and HICMOEntrySEQ={HICMOEntrySEQ} and HSourceID={HSourceID_Child}", "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 var HBillNo_New = DBUtility.ClsPub.CreateBillCode_Prod(BillType, ref DBUtility.ClsPub.sExeReturnInfo, true);//获得一个新的单据号 var HInterID_New = DBUtility.ClsPub.CreateBillID_Prod(BillType, ref DBUtility.ClsPub.sExeReturnInfo);//获得一个新的id 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" + ",HICMOInterID,HICMOEntryID,HPlanEndDate,HEmpID,HWorkQty,HSourceName,HWorkQty_ProdLine,HRemark)values" + $"({HInterID_New},'{HBillNo_New}',{DateTime.Now.Year},{DateTime.Now.Month},'{BillType}'," + $"'{BillType}',GETDATE(),1,'{user}',getdate(),'{HICMOBillNo}','{HOrderType}'," + $"{(HICMOEntrySEQ == "" ? 0.ToString() : HICMOEntrySEQ)},{(HWorkShopID == "" ? 0.ToString() : HWorkShopID)},{(HSourceID_Child == "" ? 0.ToString() : HSourceID_Child)}, {(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}," + $"{HMainSourceInterID},{HMainSourceEntryID},'{HPlanEndDate}','{HEmpID}','{HWorkQty}','{HSourceName}','{HWorkQty_ProdLine}','{"协同生产"}')"; //LogService.Write("sql:" + sql); //主表 oCN.RunProc(sql); //插入子表数据 for (int j = 0; j < 180; j++) { //主表有数据 子表无数据 //if (j == 180 - 1 && SumCount == 0 && HInterID_New != 0 && HBillNo_New != "") //{ // objJsonResult = AddBillSub(HInterID_New.ToString(), HBillNo_New, DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd").ToString()), 0, list[i]); //} if (list[i][DateTime.Now.AddDays(j).ToString("yyyy-MM-dd")].ToString() != "") { ////保存子表 objJsonResult = AddBillSub(HInterID_New == 0 ? list[i]["hmainid"].ToString() : HInterID_New.ToString() , HBillNo_New == "" ? list[i]["单据号"].ToString() : HBillNo_New , DateTime.Parse(DateTime.Now.AddDays(j).ToString("yyyy-MM-dd").ToString()) , 0 , list[i]); } } } } } else { ds = oCN.RunProcReturn($"select HInterID,HICMOBillNo from Sc_WorkBillSortBillMain with(nolock) where HMainSourceInterID={HMainSourceInterID}" + $" and HMainSourceEntryID={HMainSourceEntryID} and HICMOBillNo='{HICMOBillNo}' and HICMOEntrySEQ={HICMOEntrySEQ} and HSourceID={HSourceID}", "Sc_WorkBillSortBillMain"); if (ds.Tables[0].Rows.Count > 1) { LogService.CustomWriteLog("第" + i + 1 + "行生产资源有重复,请修改", DateTime.Now.ToString("yyyy-MM-dd")); LogService.CustomWriteLog($"select * from Sc_WorkBillSortBillMain where HMainSourceInterID={HMainSourceInterID}" + $" and HMainSourceEntryID={HMainSourceEntryID} and HICMOBillNo='{HICMOBillNo}' and HICMOEntrySEQ={HICMOEntrySEQ} and HSourceID={HSourceID}", DateTime.Now.ToString("yyyy-MM-dd")); objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = $"第{i + 1}行生产资源有重复,请修改!"; objJsonResult.data = null; return objJsonResult; } LogService.CustomWriteLog("2.2:" + i, DateTime.Now.ToString("yyyy-MM-dd")); oCN.RunProc($"update Sc_WorkBillSortBillMain set HSourceID={(HSourceID == "" ? 0.ToString() : HSourceID)},HYX={HYX}" + $",HWorkQty={HWorkQty},HProdTimes={HProdTimes},HReadyTimes={HReadyTimes},HLastBeginDate='{HLastBeginDate}'" + $",HLastEndDate='{HLastEndDate}',HOrderNeedQty={HOrderNeedQty},HOrderCommitDate='{HOrderCommitDate}',HPlanEndDate='{HPlanEndDate}',HSplitQty={HSplitQty},HSourceName='{HSourceName}',HWorkQty_ProdLine={HWorkQty_ProdLine}" + $" where HInterID={list[i]["hmainid"].ToString()} and HBillNo='{list[i]["单据号"].ToString()}'"); } } else { ds = oCN.RunProcReturn($"select HInterID,HICMOBillNo from Sc_WorkBillSortBillMain with(nolock) where HMainSourceInterID={HMainSourceInterID}" + $" and HMainSourceEntryID={HMainSourceEntryID} and HICMOBillNo='{HICMOBillNo}' and HICMOEntrySEQ={HICMOEntrySEQ} and HSourceID={HSourceID} and ISNULL(HDeleteMan,'') = ''", "Sc_WorkBillSortBillMain"); if (ds.Tables[0].Rows.Count > 1) { LogService.CustomWriteLog("第" + i + 1 + "行生产资源有重复,请修改", DateTime.Now.ToString("yyyy-MM-dd")); LogService.CustomWriteLog($"select * from Sc_WorkBillSortBillMain where HMainSourceInterID={HMainSourceInterID}" + $" and HMainSourceEntryID={HMainSourceEntryID} and HICMOBillNo='{HICMOBillNo}' and HICMOEntrySEQ={HICMOEntrySEQ} and HSourceID={HSourceID} and ISNULL(HDeleteMan,'')=''", DateTime.Now.ToString("yyyy-MM-dd")); objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = $"第{i + 1}行生产资源有重复,请修改!"; objJsonResult.data = null; return objJsonResult; } LogService.CustomWriteLog("2.2:" + i, DateTime.Now.ToString("yyyy-MM-dd")); oCN.RunProc($"update Sc_WorkBillSortBillMain set HSourceID={(HSourceID == "" ? 0.ToString() : HSourceID)},HYX={HYX}" + $",HWorkQty={HWorkQty},HProdTimes={HProdTimes},HReadyTimes={HReadyTimes},HLastBeginDate='{HLastBeginDate}'" + $",HLastEndDate='{HLastEndDate}',HOrderNeedQty={HOrderNeedQty},HOrderCommitDate='{HOrderCommitDate}',HPlanEndDate='{HPlanEndDate}',HSplitQty={HSplitQty},HSourceName='{HSourceName}',HWorkQty_ProdLine={HWorkQty_ProdLine}" + $" 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 = 0; //动态两月之差 DateTime.Now.AddMonths(1).AddDays(-1).Subtract(DateTime.Now).Days; // 统计总天数 HashSet uniqueDates = new HashSet(); foreach (var key in list[i].Keys) { if (DateTime.TryParseExact(key, "yyyy-M-d", CultureInfo.InvariantCulture, DateTimeStyles.None, out DateTime date)) { uniqueDates.Add(date); } } SumDay = uniqueDates.Count; if (oSystemParameter.omodel.WMS_CampanyName == "添康科技") //系统参数 客户定制化名称 空白为通用 { SumDay = 180; } LogService.CustomWriteLog("2.3:" + i, DateTime.Now.ToString("yyyy-MM-dd")); 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()) , Math.Round(double.Parse(list[i][DateTime.Now.AddDays(j).ToString("yyyy-MM-dd")].ToString()),1) , list[i]); if (objJsonResult.count == 1) { TrueCount += 1; } } //主表有数据 子表无数据 if (j == SumDay-1 && SumCount == 0 && HInterID != 0 && HBillNo != "") { //LogService.CustomWriteLog("3:"+ HInterID+","+ HBillNo, DateTime.Now.ToString("yyyy-MM-dd")); objJsonResult = AddBillSub(HInterID.ToString(), HBillNo, DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd").ToString()), 0, list[i]); } } LogService.CustomWriteLog("2.4:" + i, DateTime.Now.ToString("yyyy-MM-dd")); if (TrueCount != SumCount) { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = objJsonResult.Message; objJsonResult.data = null; return objJsonResult; } } LogService.CustomWriteLog("2.5:", DateTime.Now.ToString("yyyy-MM-dd")); //同步日计划工单 oCN.RunProc("exec REALESE_SC_ICMOBILLSTATUS_TMP"); LogService.CustomWriteLog("2.6:", DateTime.Now.ToString("yyyy-MM-dd")); sw.Stop();//结束计时 LogService.Write($"========================1.排产订单总用时:" + sw.Elapsed); 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, double HQTY, Dictionary dic) { string sReturn = ""; oSystemParameter.ShowBill(ref sReturn); //获取表格数据 ds = oCN.RunProcReturn($"select * from h_v_JIT_Sc_WorkBillSortBill_PC where 单据号='{HBillNo}'", "h_v_JIT_Sc_WorkBillSortBill_PC"); int count = 0; if (ds.Tables[0].Rows.Count > 0) { if (oSystemParameter.omodel.WMS_CampanyName == "添康科技") //系统参数 客户定制化名称 空白为通用 { //判断子表是否有当日的日期以及日期所对应的数量 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},HUseTimes={(dic["产线总产能"] == "0" ? 0 : HQTY / float.Parse(dic["产线总产能"].ToString()))}" + $" where HInterID={HInterID} and HEntryID={ds.Tables[0].Rows[i]["hsubid"].ToString()}"); count += 1; } } } else { //判断子表是否有当日的日期以及日期所对应的数量 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},HUseTimes={(dic["小时产能"] == "0" ? 0 : HQTY / float.Parse(dic["小时产能"].ToString()))}" + $" where HInterID={HInterID} and HEntryID={ds.Tables[0].Rows[i]["hsubid"].ToString()}"); count += 1; } } } } if (count != 1) { if (oSystemParameter.omodel.WMS_CampanyName == "添康科技") //系统参数 客户定制化名称 空白为通用 { //插入子表 oCN.RunProc("insert into Sc_WorkBillSortBillSub(HInterID,HSEQ," + "HMasterDate,HQty,HUseTimes)" + $"values({HInterID}, {(ds.Tables[0].Rows.Count + 1)}," + $" '{date}', {HQTY},{ ((dic["产线总产能"] == "0.0000" ? 0 : dic["产线总产能"] == "0" ? 0 : HQTY / float.Parse(dic["产线总产能"].ToString())).ToString() == "非数字" ? 0 : dic["产线总产能"] == "0.0000" ? 0 : dic["产线总产能"] == "0" ? 0 : HQTY / float.Parse(dic["产线总产能"].ToString())) })"); } else { //插入子表 oCN.RunProc("insert into Sc_WorkBillSortBillSub(HInterID,HSEQ," + "HMasterDate,HQty,HUseTimes)" + $"values({HInterID}, {(ds.Tables[0].Rows.Count + 1)}," + $" '{date}', {HQTY},{ ((dic["小时产能"] == "0.0000" ? 0 : dic["小时产能"] == "0" ? 0 : HQTY / float.Parse(dic["小时产能"].ToString())).ToString() == "非数字" ? 0 : dic["小时产能"] == "0.0000" ? 0 : dic["小时产能"] == "0" ? 0 : HQTY / float.Parse(dic["小时产能"].ToString())) })"); } } if (oSystemParameter.omodel.WMS_CampanyName == "添康科技") //系统参数 客户定制化名称 空白为通用 { //把排产订单完工日期反写到金蝶销售订单上 string sql = "exec h_p_JIT_UpdateEndDateToERP " + HInterID + ",'" + HBillNo + "'"; oCN.RunProc(sql); } objJsonResult.code = "1"; objJsonResult.count = 1; objJsonResult.Message = null; objJsonResult.data = null; return objJsonResult; } #endregion #region 生产日计划平台 齐套分析 #region 清单配料方式 public class PRD_PPBOM { /// /// 日计划工单号 /// public string HMainICMOBillNo { get; set; } /// /// 日计划工单FID /// public long HInterID { get; set; } /// /// 日计划明细FEntryID /// public long HEntryID { get; set; } /// /// 生产用料清单单号 /// public string HBillNo { get; set; } /// /// 生产订单单号 /// public string HICMOBillNo { get; set; } /// /// 生产订单内码 /// public string HICMOInterID { get; set; } /// /// 父级物料ID /// public string FMaterialID { get; set; } /// /// 父级物料数量 /// public decimal FQty { get; set; } /// /// 子项物料ID /// public string FMATERIALID2 { get; set; } /// /// 子项物料名称 /// public string FNumber { get; set; } /// /// 需求数量 /// public decimal FNeedQty { get; set; } /// /// 即时库存 /// public decimal FBASEQTY { get; set; } /// /// 生产订单主码 /// public string HICMOInterID_Sec { get; set; } /// /// 生产订单子码 /// public string HICMOEntryID_Sec { get; set; } /// /// 日计划数量 /// public string HQty { get; set; } /// /// 日计划日期 /// public DateTime HMasterDate { get; set; } /// /// 订单等级 /// public string HOrderLev { get; set; } /// /// 库存组织 /// public string FStockOrgId { get; set; } /// /// 组织名称 /// public string OrgFnumber { get; set; } /// /// 单位用量 /// public decimal dwyl { get; set; } /// /// 预计消耗用量 /// public decimal PlanCount { get; set; } /// /// 物料属性 /// public int FErpClsID { get; set; } /// /// 车间 /// public string HWorkShopID { get; set; } /// /// 车间编码 /// public string FHWorkShopNumber { get; set; } } #endregion #region 即时库存 public class PRD_Inventory { /// /// 物料ID /// public string FMATERIALID { get; set; } /// /// 物料编码 /// public string FNumber { get; set; } /// /// 即时库存 /// public decimal FBASEQTY { get; set; } /// /// 库存组织 /// public string FStockOrgId { get; set; } /// /// 库存货主类型 /// public string FOwnerTypeId { get; set; } /// /// 库存货主 /// public string FOwnerId { get; set; } /// /// 货主编码 /// public string FOwnerNumber { get; set; } /// /// 仓库 /// public string FSTOCKID { get; set; } /// /// 仓库编码 /// public string FStockNumber { get; set; } /// /// 批号 /// public string HLOT { get; set; } /// /// id /// public string HInventoryFID { get; set; } } #endregion #region 车间仓库对照列表 public class PRD_WorkHouseCompar { /// /// 组织 /// public string FORGID { get; set; } /// /// 车间 /// public string FWORKSHOPID { get; set; } /// /// 仓库 /// public string FSTOCKID { get; set; } } #endregion #region 日计划+生产订单 public class DayPlanPickedModel { /// /// 订单入库数量 按照生产订单明细行 /// public decimal FCXStockInQty { get; set; } /// /// 主生产订单子内码 /// public string FPRDMOENTYID { get; set; } /// /// 物料单位用量 /// public decimal dwyl { get; set; } /// /// 已领数量 /// public decimal FPickedQty { get; set; } /// /// 剩余可用数量 /// public decimal FRemainPickedQty { get; set; } /// /// 物料 /// public string FMATERIALID { get; set; } } #endregion #region 存储临时需要插入数据 public class CompleteAnalysisTempModel { /// /// 主生产订单主内码:FHMainICMOInterIDr /// public string FHMainICMOInterIDr { get; set; } /// /// 主生产订单子内码:FHMainICMOEntryID /// public string FHMainICMOEntryID { get; set; } /// /// 日计划订单单号:HMainICMOBillNo /// public string HMainICMOBillNo { get; set; } /// /// 日计划订单主内码:FHICMOInterID /// public string FHICMOInterID { get; set; } /// /// 日计划订单子内码:FHICMOEntryID /// public string FHICMOEntryID { get; set; } /// /// 子件物料:FHMaterID /// public string FHMaterID { get; set; } /// /// 库存组织:FHStockOrgID /// public string FHStockOrgID { get; set; } /// ///生产组织:FHPRDORGID /// public string FHPRDORGID { get; set; } /// /// 生产订单号:FPRDBillNo /// public string FPRDBillNo { get; set; } /// /// 标识 /// public string FIdentificat { get; set; } /// /// 货主名称:FOwnerName /// public string FOwnerName { get; set; } /// /// 货主编码:FOwnerId /// public string FOwnerId { get; set; } /// /// 货主类型:FOwnerTypeId /// public string FOwnerTypeId { get; set; } /// /// 齐套状态 /// public string FComPlete { get; set; } /// /// 数量 /// public string FHUseQty { get; set; } /// /// 及时库存数量:FHStockQty /// public decimal FHStockQty { get; set; } /// ///可用数量:FHLeftQty /// public decimal FHLeftQty { get; set; } /// /// 缺料数量 /// public decimal FLackCount { get; set; } /// /// 占用数量 /// public decimal FOccupyCount { get; set; } /// /// 占用领料数量 /// public decimal FOccupyPickedCount { get; set; } /// /// 单位用量:FUnitDosage /// public decimal FUnitDosage { get; set; } /// /// 计划总数量:FSumPlanCount /// public decimal FSumPlanCount { get; set; } /// /// 齐套数量:FCompleteCount q /// public decimal FCompleteCount { get; set; } public decimal FCompleteCount1 { get; set; } /// /// 日计划日期 /// 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 #region 齐套分析 原调用方法 public object JIT_CompleteSetAnalysis_Old(string sWhere, string user) { try { Stopwatch sw = new Stopwatch(); omdelMian = JsonConvert.DeserializeObject(sWhere); string sql = $"exec JIT_qtfx {omdelMian.HProdORGID},{omdelMian.HWorkShopID},'{user}' "; ds = oCN.RunProcReturn(sql, "JIT_qtfx"); //LogService.Write("齐套分析sql:" + sql); List BomList = new List(); DataTable resulTable = ds.Tables[0]; if (ds.Tables[0].Rows.Count < 1 || ds == null) { //释放齐套操作 避免多人同时进行齐套分析 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; } 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(); } 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 fidList = BomList.Select(x => x.HInterID.ToString()).Distinct().ToList(); List fentryidList = BomList.Select(x => x.HEntryID.ToString()).Distinct().ToList(); fDayPlanFids = string.Join(",", fidList); fDayPlanFEntryids = string.Join(",", fentryidList); } //LogService.Write("日计划工单ids" + fDayPlanFids); sw.Start();//开始计时 //获取当前即时库存 库存数量+库存组织+物料+货主+仓库 //原查询即时库存方式:select * from h_v_jit_InventoryList ds = oCN.RunProcReturn(@" exec h_p_jit_Inventory_UsableList ", "h_p_jit_Inventory_UsableList"); ListInventory = ds.ToModelList(); //车间 仓库对照列表 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 = ds.ToModelList(); 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 不要取值需求数量FNeedQty 领料数据 string LLsql = string.Format(@"exec h_p_jit_PPBOMList '{0}'", fDayPlanFids); List DayPlanPickedModel = new List(); //LogService.Write("LLsql:" + LLsql); ds = oCN.RunProcReturn(LLsql, "SC_WORKBILLSORTBILLMAIN"); //LogService.Write(JsonConvert.SerializeObject(ds)); DayPlanPickedModel = ds.ToModelList(); //LogService.Write(JsonConvert.SerializeObject(DayPlanPickedModel)); //CompleteAnalysisTempModel 用于存储临时需要插入数据 List completeAnalysisTempModel = new List(); //创建字典 用于储存物料 + 占用数量 Dictionary occupyDic = new Dictionary(); //LogService.Write($"齐套分析,数据准备阶段,用时" + sw.Elapsed + "总行数:" + BomList.Count); //LogService.Write($"齐套分析,数据准备阶段,用时" + sw.Elapsed + "总需要循环的bom数量:" + DatePlanList.Count); //第一个循环 日计划工单明细 一天+一个工单 一个循环 int o = 0; foreach (var item in DatePlanList) { o++; //LogService.Write("循环:" + o); //日计划用料清单明细 每一天的实际用料情况 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;//用于计算当时那个计算节点的即时库存 //计算当前这几个仓库总的库存量 if (_pRD_WorkHouseCompar.Count > 0) { foreach (var _WorkHouse in _pRD_WorkHouseCompar) { //库存数据匹配 List _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 //车间 }); //扣除剩余可用领料数量 _DayPlanPickedModel.FRemainPickedQty -= need; //LogService.Write($"h" + need); //循环下一个物料 continue; } else { //LogService.Write($"kxs" + need); need -= _DayPlanPickedModel.FRemainPickedQty; //剩余需求数量 //LogService.Write($"i1" + need); FOccupyPickedCount = _DayPlanPickedModel.FRemainPickedQty; _DayPlanPickedModel.FRemainPickedQty = 0; //LogService.Write($"i" + need); } if (_pRD_WorkHouseCompar.Count > 0) { //缺料数量 需求数量 - 实际库存 >0 ? 一个物料不管占用多少条 库存+货主 数据 缺料数量是同一个数量 decimal _fLackCount = need > jskcQty ? (need - jskcQty) : 0; //LogService.Write($"j" + _fLackCount); //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; } //LogService.Write($"k" + 2); foreach (var WorkHouse in _pRD_WorkHouseCompar) { //库存数据匹配 List _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 }); //扣减总库存数量 jskcQty = jskcQty >= fCompleteCount ? jskcQty - fCompleteCount : 0; //剩余日计划需求数量 need = need >= Inventory.FBASEQTY ? need - Inventory.FBASEQTY : 0; //扣减消耗库存 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($"齐套分析,数据准备完成,保存到Model实体,总行数:{completeAnalysisTempModel.Count},耗时:" + sw.Elapsed); List sqlList = new List(); 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 齐套分析调用方法 20250402 [Route("JIT_DayPlanPlatFormBill/JIT_CompleteSetAnalysis")] [HttpGet] public object JIT_CompleteSetAnalysis(string sWhere, string user) { try { string sErrMsg = ""; if (oSystemParameter.ShowBill(ref sErrMsg) == true) { if (oSystemParameter.omodel.WMS_CampanyName == "帅威" || oSystemParameter.omodel.WMS_CampanyName == "凯贝奈特" || oSystemParameter.omodel.WMS_CampanyName == "添康科技" || oSystemParameter.omodel.WMS_CampanyName == "宝工") //系统参数 客户定制化名称 空白为通用 { objJsonResult = (json)JIT_CompleteSetAnalysis_Old(sWhere, user); } else { objJsonResult = (json)JIT_CompleteSetAnalysis_New(sWhere, user); } return objJsonResult; } else { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = "获取系统参数失败! " + sErrMsg; 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; } } /// /// 齐套分析 新调用方法 /// /// public object JIT_CompleteSetAnalysis_New(string sWhere, string user) { try { omdelMian = JsonConvert.DeserializeObject(sWhere); string HWorkShopID = omdelMian.HWorkShopID.ToString(); var HStockOrgID = omdelMian.HProdORGID; ds = oCN.RunProcReturn("exec h_p_JIT_CompleteSetAnalysis " + HWorkShopID.ToString() + ",'" + user + "'," + HStockOrgID.ToString(), "h_p_JIT_CompleteSetAnalysis"); if (ds == null || ds.Tables[0].Rows.Count == 0) { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = "齐套分析发生错误!"; objJsonResult.data = null; return objJsonResult; } else if (DBUtility.ClsPub.isLong(ds.Tables[0].Rows[0]["HBack"]) == 1) { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = DBUtility.ClsPub.isStrNull(ds.Tables[0].Rows[0]["HRemark"]); objJsonResult.data = null; return objJsonResult; } else { objJsonResult.code = "0"; objJsonResult.count = 1; objJsonResult.Message = DBUtility.ClsPub.isStrNull(ds.Tables[0].Rows[0]["HRemark"]); //运算成功 objJsonResult.data = null; return objJsonResult; } } catch (Exception e) { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = "齐套分析失败!" + e.ToString(); objJsonResult.data = null; return objJsonResult; } } #endregion #endregion #region 生产日计划平台 提料运算 #region 日计划展开数据明细 public class DayPlanPpbom { /// /// 日计划工单主ID /// public long FID { get; set; } /// /// 生产订单号 /// public string FBILLNO { get; set; } /// /// 日计划明细日期 /// public DateTime FHMASTERDATE { get; set; } /// /// 日计划明细数量 /// public decimal FHQTY { get; set; } /// /// 齐套数 /// public decimal FCOMPLETECOUNT { get; set; } /// /// 生产订单工单ID /// public long FPRDMOMAINID { get; set; } /// /// 子表ID /// public int FENTRYID { get; set; } /// /// 单位用料 /// public decimal FNeedQty { get; set; } /// /// 物料ID /// public string FMATERIALID { get; set; } /// /// 提前天数 /// public int FFIXLEADTIME { get; set; } /// ///最大包装 /// public decimal FMAXPOQTY { get; set; } /// /// 最小包装量 /// public decimal FMINPOQTY { get; set; } /// /// 物料编码 /// public string FNumber { get; set; } /// /// 实际需求 /// public decimal NeedQty { get; set; } /// /// 库存组织 /// public long FStockOrgId { get; set; } //库存组织名称 public string FStockOrgName { get; set; } /// /// jit物料分类 /// public string FJITmaterialGroup { get; set; } /// /// JIT物料需求供货周期 /// public string FJITMaterielDemand { get; set; } /// /// JIT安全库存 /// public string FJITSafeStock { get; set; } /// /// 物料属性 /// public string FErpClsID { get; set; } /// /// 需求单号(销售订单号) /// public string FXQD { get; set; } /// /// 日计划工单单号 /// public string FDAYPLANBILLNO { get; set; } /// /// 生产车间编码 /// public string FWORKSHOPNUMBER { get; set; } } #endregion #region 采购订单物料库存 public class PurchaseInventory { /// /// 采购FID /// public long FID { get; set; } //采购订单单号 public string FBillNo { get; set; } /// /// 采购子表标识 /// public long FENTRYID { get; set; } /// /// 供应商id /// public long FSUPPLIERID { get; set; } /// /// 供应商名称 /// public string FNUMBER { get; set; } /// /// 物料ID /// public string FMATERIALID { get; set; } /// /// 物料编码 /// public string FMATERIALNUMBER { get; set; } /// /// 采购数量 /// public decimal FQTY { get; set; } /// /// 采购组织 /// public long FStockOrgId { get; set; } /// /// 采购组织名称 /// public string FStockOrgName { get; set; } /// /// 组织编码 /// public string FORGNumber { get; set; } /// /// 提前期 /// public int FFIXLEADTIME { get; set; } /// /// 需求单号 /// public string FXQD { get; set; } /// /// 采购订单上的创建人 /// public string FCREATORID { get; set; } /// /// 采购订单上的创建人名称 /// public string FName { get; set; } /// /// 采购订单上的采购日期 /// public DateTime FDate { get; set; } /// /// 采购订单上的交货日期 /// public DateTime FDeliveryDate { get; set; } /// /// 采购订单表头摘要 /// public string F_QIMB_NOTE { get; set; } /// /// 采购订单表体备注 /// public string FNOTE { get; set; } //采购部门 public string FPURCHASEDEPTNUMBER { get; set; } /// /// 收料但是没入库部分 需要优先去扣除 /// public decimal FReceiveNotInQty { get; set; } /// /// 采购订单数量 /// public decimal FPURCHASEQTY { get; set; } /// /// 采购订单关联数量 /// public decimal FJOINQTY { get; set; } /// /// 收料单数量 /// public decimal FReceiveQty { get; set; } } #endregion #region 提料计划临时储存 public class PODemandPlanTemp { /// /// 日计划工单主ID /// public long FID { get; set; } /// /// 日计划工单编号 /// public string FBILLNO { get; set; } /// /// 日计划明细日期 /// public DateTime FHMASTERDATE { get; set; } /// /// 日计划明细数量 /// public decimal FHQTY { get; set; } /// /// 生产订单工单ID /// public long FPRDMOMAINID { get; set; } /// /// 子表ID /// public int FENTRYID { get; set; } /// /// 数量 /// public decimal FQty { get; set; } /// /// 物料ID /// public string FMATERIALID { get; set; } /// /// 物料编码 /// public string FNumber { get; set; } /// /// 采购FID /// public long PurchseFID { get; set; } /// /// 采购订单单号 /// public string PurchseFBillNo { get; set; } /// /// 采购子表标识 /// public long PurchseFentryID { get; set; } /// /// 供应商id /// public long FSUPPLIERID { get; set; } /// /// 供应商名称 /// public string PurchseFNUMBER { get; set; } /// /// 日计划日期 /// public DateTime OLDDATE { get; set; } /// /// 采购订单数量 /// public decimal PurchseFqty { get; set; } /// /// 提前期 /// public double FFIXLEADTIME { get; set; } /// /// 采购组织 /// public long FStockOrgId { get; set; } /// /// 采购组织名称 /// public string FStockOrgName { get; set; } /// /// 组织编码 /// public string FORGNumber { get; set; } /// /// 物料属性 /// public string FErpClsID { get; set; } /// /// 需求单号 /// public string FXQD { get; set; } /// /// 采购订单上的创建人 /// public string FCREATORID { get; set; } /// /// 采购订单上的创建人名称 /// public string FName { get; set; } /// /// 采购订单上的采购日期 /// public DateTime FDate { get; set; } /// /// 采购订单上的交货日期 /// public DateTime FDeliveryDate { get; set; } /// /// 采购订单表头摘要 /// public string F_QIMB_NOTE { get; set; } /// /// 采购订单表体备注 /// public string FNOTE { get; set; } /// /// 采购部门 /// public string FPURCHASEDEPTNUMBER { get; set; } /// /// 日计划工单单号 /// public string FDAYPLANBILLNO { get; set; } /// /// 生产车间编码 /// public string FWORKSHOPNUMBER { get; set; } /// /// 采购订单数量 /// public decimal FPURCHASEQTY { get; set; } /// /// 采购订单关联数量 /// 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(sWhere); string fProWorkShopId = omdelMian.HWorkShopID.ToString(); var fPrdOrgId = omdelMian.HProdORGID; string sqlName = "";//AIS20210811135644 string WMS_CampanyName = ""; //客户名称 //客户制定 string sErr = ""; if (oSystemParameter.ShowBill(ref sErr)) { if (oSystemParameter.omodel.WMS_CampanyName == "帅威") { sqlName = "AIS20230129011339"; WMS_CampanyName = "帅威"; } else if (oSystemParameter.omodel.WMS_CampanyName == "凯贝奈特") { sqlName = "AIS20210820164804"; WMS_CampanyName = "凯贝奈特"; } else if (oSystemParameter.omodel.WMS_CampanyName == "添康科技") { sqlName = "AIS20240809105013"; WMS_CampanyName = "添康科技"; } else if (oSystemParameter.omodel.WMS_CampanyName == "宝工") { sqlName = "AIS20250102123554"; WMS_CampanyName = "宝工"; } else { sqlName = "AIS20210811135644"; } if (WMS_CampanyName == "宝工") { objJsonResult = (json)JIT_MOMaterLack(fProWorkShopId, fPrdOrgId, user); } else if (HTLType == "缺料") { if (WMS_CampanyName == "帅威" || WMS_CampanyName == "凯贝奈特" || WMS_CampanyName == "添康科技") { objJsonResult = (json)JIT_QL(fProWorkShopId, fPrdOrgId, user, sqlName); } else { objJsonResult = (json)JIT_MOMaterReady(fProWorkShopId, fPrdOrgId, user); } } else if (HTLType == "生产用料清单") { objJsonResult = (json)JIT_PPBOM(fProWorkShopId, fPrdOrgId, user, sqlName); } return objJsonResult; } else { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = "获取系统参数失败! " + sErr; 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; } } /// /// 通过缺料情况算提料 /// /// 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("[提料计划准备阶段]提料计划预处理sql:" + sql); //采购订单数据 string sql = $@"exec h_p_JIT_MOMaterReady {HWorkShopID},{HProdORGID},2"; DataSet ds = oCN.RunProcReturn(sql, "t_PUR_POOrderEntry"); List PurchaseInventory = ds.ToModelList(); ////LogHelper.Info("[提料计划准备阶段]可用采购订单数据sql:" + sql); sql = string.Format($@"exec h_p_JIT_MOMaterReady {HWorkShopID},{HProdORGID},3"); ////LogHelper.Info("[提料计划准备阶段]需要提料数据sql:" + sql); ds = oCN.RunProcReturn( sql, "JIT_MOMaterReadysBill"); List DayPlanPpbom = ds.ToModelList(); //物料+库存组织分类 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 = new List(); //sql集合 更新采购订单占用的提料计划数量 List sqlList = new List(); //LogService.Write("1"); string Error = ""; foreach (var item in MaterialIDList) { //当前物料没有采购订单时 直接跳出 List _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; } //LogService.Write("1.1"); ////LogHelper.Info(item.FMATERIALID.ToString()); //当前物料和库存组织对应的需进行提料计划的数据 List _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 //LogService.Write("1.2"); List FEntryIdList = new List(); 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; } //LogService.Write("1.2.1"); if (NeedQty == 0) { DATE = Convert.ToDateTime(_item.FHMASTERDATE).AddDays(-FFIXLEADTIME); } FEntryIdList.Add(_item.FENTRYID); NeedQty += _item.NeedQty; //LogService.Write(FJITmaterialGroup); //LogService.Write(FEntryIdList.Count); //LogService.Write(Convert.ToDouble(FJITMaterielDemand)); //LogService.Write(_DayPlanPpbom.Count); //LogService.Write(i); if ((FJITmaterialGroup == "总量控制规格类" || FJITmaterialGroup == "订单专用个性类") && FEntryIdList.Count < Convert.ToDouble(FJITMaterielDemand) && i < _DayPlanPpbom.Count) //订单专用个性类 { continue; } //LogService.Write("1.2.2"); 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, FDAYPLANBILLNO = _item.FDAYPLANBILLNO }); //扣除日计划明细已被分配的数量 DayPlanPpbomls.NeedQty = 0; } //LogService.Write("1.2.3"); FEntryIdList.Clear(); //更新采购订单 //sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount =isnull(FPODemandPlanCount,0)+ '{NeedQty}' where FENTRYID = {Purchase.FENTRYID}"); //扣除当前行对应采购订单数量 var ls = PurchaseInventory.Where(c => c.FENTRYID == Purchase.FENTRYID).FirstOrDefault(); ls.FQTY -= NeedQty; break; } else { //更新总需求数量 NeedQty = NeedQty - Purchase.FQTY; //采购订单数量 decimal _NeedQty = Purchase.FQTY; List mmm = new List(); 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, FDAYPLANBILLNO = _item.FDAYPLANBILLNO }); //更新计划数量(剩余需要排的) 继续去计算下一个采购订单 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); } } } //LogService.Write("1.2.4"); 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($"提料计划,数据准备完成,保存到Model实体,总行数:{PODemandPlanTemp.Count}"); int tlmmm = 0; JArray FinalyResult = new JArray(); //LogService.Write("2"); 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 _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);//日计划工单FID //FentityModel.Add("FHSourceEntryID", _item.FENTRYID);//日计划工单FENTRYID //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);// 采购订单内码:FHPOOrderInterID //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 = ""; //物料代码 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(); //物料代码 HMaterName = dataSet.Tables[0].Rows[0]["HName"].ToString(); //物料名称 } decimal HQty = _item.FQty; //数量 long HSourceInterID = _item.FID; //日计划工单FID long HSourceEntryID = _item.FENTRYID;//日计划工单FENTRYID 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++; } //LogService.Write("3"); if (Error != "") { oCN.Commit(); objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = "运算成功!" + Error; objJsonResult.data = null; return objJsonResult; } else if (tlmmm == PODemandPlanList.Count && tlmmm != 0) { oCN.Commit(); objJsonResult.code = "1"; objJsonResult.count = 1; objJsonResult.Message = "运算成功!" + Error; 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; } } /// /// 通过生产用料清单 算缺料情况 /// /// 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 = ds.ToModelList(); 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 = ds.ToModelList(); //物料+库存组织分类 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 = new List(); //sql集合 更新采购订单占用的提料计划数量 List sqlList = new List(); foreach (var item in MaterialIDList) { //this.View.Session["ProcessRateValue"] = Convert.ToInt32((Convert.ToDecimal(75) / MaterialIDList.Count) * i); //当前物料和库存组织对应的需进行提料计划的数据 List _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 }); //扣除日计划明细已被分配的数量 _item.NeedQty = 0; //扣除当前行对应采购订单数量 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; //扣除日计划明细已被分配的数量 _item.NeedQty -= _NeedQty; //扣除当前行对应采购订单数量 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}"); //扣除日计划明细已被分配的数量 _item.NeedQty = 0; //扣除当前行对应采购订单数量 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}"); //扣除日计划明细已被分配的数量 _item.NeedQty -= _NeedQty; //扣除当前行对应采购订单数量 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("提料计划重算 ,数据准备完成,保存到Model实体 用时:" + 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 _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 = ""; //物料代码 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(); //物料代码 HMaterName = dataSet.Tables[0].Rows[0]["HName"].ToString(); //物料名称 } decimal HQty = _item.FQty; //数量 long HSourceInterID = _item.FID; //日计划工单FID long HSourceEntryID = _item.FENTRYID;//日计划工单FENTRYID 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; } } /// /// 通过欠料表 算提料 宝工 /// /// public object JIT_MOMaterLack(string HWorkShopID, int? HProdORGID, string user) { try { ds = oCN.RunProcReturn("exec h_p_JIT_PODemandPlanBill_MOMaterLack " + HWorkShopID.ToString() + ",'" + user + "'," + HProdORGID.ToString(), "h_p_JIT_PODemandPlanBill_MOMaterLack"); if (ds == null || ds.Tables[0].Rows.Count == 0) { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = "提料运算发生错误!"; objJsonResult.data = null; return objJsonResult; } else if (DBUtility.ClsPub.isLong(ds.Tables[0].Rows[0]["HBack"]) == 1) { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = DBUtility.ClsPub.isStrNull(ds.Tables[0].Rows[0]["HRemark"]); objJsonResult.data = null; return objJsonResult; } else { objJsonResult.code = "0"; objJsonResult.count = 1; objJsonResult.Message = DBUtility.ClsPub.isStrNull(ds.Tables[0].Rows[0]["HRemark"]); //运算成功 objJsonResult.data = null; return objJsonResult; } } catch (Exception e) { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = "提料运算失败!" + e.ToString(); objJsonResult.data = null; return objJsonResult; } } /// /// 通过齐套表 算提料 /// /// public object JIT_MOMaterReady(string HWorkShopID, int? HProdORGID, string user) { try { ds = oCN.RunProcReturn("exec h_p_JIT_PODemandPlanBill_MOMaterReady " + HWorkShopID.ToString() + ",'" + user + "'," + HProdORGID.ToString(), "h_p_JIT_PODemandPlanBill_MOMaterReady"); if (ds == null || ds.Tables[0].Rows.Count == 0) { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = "提料运算发生错误!"; objJsonResult.data = null; return objJsonResult; } else if (DBUtility.ClsPub.isLong(ds.Tables[0].Rows[0]["HBack"]) == 1) { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = DBUtility.ClsPub.isStrNull(ds.Tables[0].Rows[0]["HRemark"]); objJsonResult.data = null; return objJsonResult; } else { objJsonResult.code = "0"; objJsonResult.count = 1; objJsonResult.Message = DBUtility.ClsPub.isStrNull(ds.Tables[0].Rows[0]["HRemark"]); //运算成功 objJsonResult.data = null; return objJsonResult; } } catch (Exception e) { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = "提料运算失败!" + e.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 生产日计划平台 解锁 [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_DayPlanPlatFormBillHLockedOrder")] [HttpGet] public object JIT_DayPlanPlatFormBillHLockedOrder(string HInterIDs) { try { oCN.RunProc($"update Sc_WorkBillSortBillMain set HLockOrder = 1 where HInterID in ({HInterIDs})"); 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_DayPlanPlatFormBillHUnlockOrder")] [HttpGet] public object JIT_DayPlanPlatFormBillHUnlockOrder(string HInterIDs) { try { oCN.RunProc($"update Sc_WorkBillSortBillMain set HLockOrder = 0 where HInterID in ({HInterIDs})"); 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 listdt = new List(); 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 = "生产明细行重复,重复的生产订单号:" + dt.Tables[0].Rows[i]["生产订单号"].ToString() + ",明细行号:" + dt.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 #region 生产日计划平台 数据准备 设置任务单相关信息 [Route("JIT_DayPlanPlatFormBill/ReadyData")] [HttpGet] public object ReadyData(string SWhere) { try { var list = SWhere.Split(','); DataTable dt = new DataTable("date"); dt.Columns.Add("HICMOInterID", typeof(string)); dt.Columns.Add("HICMOEntryID", typeof(string)); dt.Columns.Add("小时产能", typeof(string)); dt.Columns.Add("生产周期", typeof(decimal)); dt.Columns.Add("开工余量", typeof(decimal)); dt.Columns.Add("最迟开工日期", typeof(DateTime)); dt.Columns.Add("最迟完工日期", typeof(DateTime)); dt.Columns.Add("订单需求数量", typeof(decimal)); dt.Columns.Add("订单交货期", typeof(DateTime)); for (int i = 0; i < list.Length; i++) { string HICMOInterID = list[i].Split(';')[0].ToString(); string HICMOEntryID = list[i].Split(';')[1].ToString(); string HSourceID = list[i].Split(';')[2].ToString(); Thread.Sleep(100); ds = oCN.RunProcReturn("exec h_p_Sc_GetInfoByICMOBillNo " + HICMOInterID+","+ HICMOEntryID+","+ HSourceID, "h_p_Sc_GetInfoByICMOBillNo"); if (ds == null || ds.Tables[0].Rows.Count == 0) { } else { DataRow dr = dt.NewRow(); dr["小时产能"] = DBUtility.ClsPub.isSingle(ds.Tables[0].Rows[0]["产能"]); dr["生产周期"] = DBUtility.ClsPub.isSingle(ds.Tables[0].Rows[0]["生产周期"]); dr["开工余量"] = DBUtility.ClsPub.isSingle(ds.Tables[0].Rows[0]["开工余量"]); dr["最迟开工日期"] = DBUtility.ClsPub.isDate(ds.Tables[0].Rows[0]["最迟开工日期"]); dr["最迟完工日期"] = DBUtility.ClsPub.isDate(ds.Tables[0].Rows[0]["最迟完工日期"]); dr["订单需求数量"] = DBUtility.ClsPub.isSingle(ds.Tables[0].Rows[0]["订单需求数"]); dr["订单交货期"] = DBUtility.ClsPub.isDate(ds.Tables[0].Rows[0]["订单交货期"]); dr["HICMOInterID"] = DBUtility.ClsPub.isSingle(ds.Tables[0].Rows[0]["HICMOInterID"]); dr["HICMOEntryID"] = DBUtility.ClsPub.isSingle(ds.Tables[0].Rows[0]["HICMOEntryID"]); dt.Rows.Add(dr); } } objJsonResult.code = "1"; objJsonResult.count = 1; objJsonResult.Message = "Sucess!"; objJsonResult.data = dt; return objJsonResult; } catch (Exception e) { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = "Exception!" + e.ToString(); objJsonResult.data = null; return objJsonResult; } } #endregion #region 缺料分析报表 public class MaterialShorAnalysis { public int? HORGID; public DateTime HBEGINDATE; public DateTime HENDDATE; } [Route("JIT_DayPlanPlatFormBill/MaterialShorAnalysisReport")] [HttpGet] public object MaterialShorAnalysisReport(string sWhere) { try { MaterialShorAnalysis Report = JsonConvert.DeserializeObject(sWhere); ds = oCN.RunProcReturn($"exec h_p_JIT_MaterialShorAnalysisReportList {Report.HORGID},'{Report.HBEGINDATE}','{Report.HENDDATE}' ", "h_p_JIT_PODemandPlanBill_ReportList"); 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; } } #endregion #region 根据物料ID获取工艺路线 列表 [Route("JIT_DayPlanPlatFormBill/GetRoutingListByMater")] [HttpGet] public object GetRoutingListByMater(int HMaterID, string user) { try { List columnNameList = new List(); int IsHavingPermissions = 1; //判断是否有工艺路线编辑权限 if (!DBUtility.ClsPub.Security_Log("Gy_RoutingBill_Edit", 1, false, user)) { IsHavingPermissions = 0; } ds = oCN.RunProcReturn("select * from h_v_JIT_GetRoutingList_Mater where HMaterID = " + HMaterID , "h_v_JIT_GetRoutingList_Mater"); if (ds == null || ds.Tables[0].Rows.Count == 0) { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = "当前物料没有维护工艺路线!请联系计划部进行维护"; objJsonResult.data = ds.Tables[0]; objJsonResult.IsHavingPermissions = IsHavingPermissions; return objJsonResult; } else { //添加列名 foreach (DataColumn col in ds.Tables[0].Columns) { Type dataType = col.DataType; string ColmString = "{\"ColmCols\":\"" + col.ColumnName + "\",\"ColmType\":\"" + dataType.Name + "\"}"; columnNameList.Add(JsonConvert.DeserializeObject(ColmString));//获取到DataColumn列对象的列名 } objJsonResult.code = "1"; objJsonResult.count = 1; objJsonResult.Message = "Sucess!"; objJsonResult.data = ds.Tables[0]; objJsonResult.list = columnNameList; objJsonResult.IsHavingPermissions = IsHavingPermissions; 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_ICMOBillListByDept")] [HttpGet] public object JIT_ICMOBillListByDept(string HDeptID) { try { //获取显示系统参数 string sReturn = ""; oSystemParameter.ShowBill(ref sReturn); //查询选择车间中未排产过的生产订单信息(添康科技--生产订单状态为下达) ds = oCN.RunProcReturn($"exec h_p_JIT_ICMOBillListByDept '{HDeptID}'", "h_p_JIT_ICMOBillListByDept"); if (ds.Tables[0].Rows.Count > 0 && ds != null) { if (oSystemParameter.omodel.WMS_CampanyName == "添康科技") //系统参数 客户定制化名称 空白为通用 { //数据表格添加动态日期 for (int j = 1; j <= 180; j++) { ds.Tables[0].Columns.Add(DateTime.Now.AddDays(j - 1).ToString("yyyy-MM-dd"), typeof(Int32)); } } else { //数据表格添加动态日期 for (int j = 1; j <= 31; j++) { ds.Tables[0].Columns.Add(DateTime.Now.AddDays(j - 1).ToString("yyyy-MM-dd"), typeof(Int32)); } } objJsonResult.code = "1"; objJsonResult.count = 1; objJsonResult.Message = "Sucess!"; objJsonResult.data = ds.Tables[0]; return objJsonResult; } else { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = "查无数据,当前所选车间下暂无未排产且订单状态为下达的生产订单信息!"; objJsonResult.data = ""; 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/GetICMOCompletionDate")] [HttpGet] public object GetICMOCompletionDate(string HDeptID) { try { //更新日计划工单的完工日期 oCN.RunProc($"exec h_p_JIT_GetICMOCompletionDate '{HDeptID}'"); objJsonResult.code = "1"; objJsonResult.count = 1; objJsonResult.Message = "获取完工日期成功!"; 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/GetICMOEarlyDate")] [HttpGet] public object GetICMOEarlyDate(string HDeptID) { try { //更新生产订单的最早开工日期 oCN.RunProc($"exec h_p_JIT_GetICMOEarlyDate '{HDeptID}'"); objJsonResult.code = "1"; objJsonResult.count = 1; objJsonResult.Message = "获取最早开工日期成功!"; 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/GetMouldByMater")] [HttpGet] public object GetMouldByMater(string HMaterID,string HSourceID,string HPCDate) { try { ds = oCN.RunProcReturn("exec h_p_Gy_MaterialMouldByMater " + HMaterID + "," + HSourceID + ",'" + HPCDate + "'", "h_p_Gy_MaterialMouldByMater"); 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; } } #endregion #region 通过资源匹配资源器具清单 [Route("JIT_DayPlanPlatFormBill/GetMouldBySource")] [HttpGet] public object GetMouldBySource(string HSourceID, string HMouldID) { try { ds = oCN.RunProcReturn("select * from h_v_Gy_SourceMouldBillMainList where HSourceID = " + HSourceID + " and HMouldID = " + HMouldID, "h_v_Gy_SourceMouldBillMainList"); 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; } } #endregion #region 排产后将器具占用时间写入数据库 [Route("JIT_DayPlanPlatFormBill/AddMouldOccupancyTime")] [HttpGet] public object AddMouldOccupancyTime(string HMouldID, string HSourceID, string HICMOInterID, string HICMOEntryID, string HICMOBillNo, string HMouldPCTime) { try { ds = oCN.RunProcReturn("exec h_p_JIT_AddMouldOccupancyTime " + HMouldID + "," + HSourceID + "," + HICMOInterID + "," + HICMOEntryID + ",'" + HICMOBillNo + "','" + HMouldPCTime + "'", "h_p_JIT_AddMouldOccupancyTime"); objJsonResult.code = "1"; objJsonResult.count = 1; objJsonResult.Message = "Sucess!"; objJsonResult.data = ""; 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/GetChildSource")] [HttpGet] public object GetChildSource(string HSourceID) { try { ds = oCN.RunProcReturn("select HItemID 子资源ID,HNumber 子资源代码,HName 子资源名称,HCubicleQty 子资源工位数 from Gy_Source with(nolock) where HParentID = " + HSourceID + " order by HName asc", "Gy_Source"); 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; } } #endregion #region 判断物料是否可以放在同一资源上一起生产 [Route("JIT_DayPlanPlatFormBill/GetSourceByMater")] [HttpGet] public object GetSourceByMater(string HMaterID) { try { ds = oCN.RunProcReturn("exec h_p_Sc_ICMOGetWorkSource_TK " + HMaterID + ",'',''", "h_p_Sc_ICMOGetWorkSource_TK"); 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; } } #endregion #region 工序负荷分析汇总报表 查询 /// /// 返回项目阶段列表 ///参数:string sql。 ///返回值:object。 /// [Route("JIT_DayPlanPlatFormBill/JIT_FuHeFenXiReport")] [HttpGet] public object JIT_FuHeFenXiReport(string sWhere, string user) { try { //查看权限 if (!DBUtility.ClsPub.Security_Log("JIT_FuHeFenXiReport", 1, false, user)) { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = "无查看权限!"; objJsonResult.data = null; return objJsonResult; } List columnNameList = new List(); string sql = "exec h_p_JIT_FuHeFenXiReport '" + sWhere + "','" + user + "'"; ds = oCN.RunProcReturn(sql, "h_p_JIT_FuHeFenXiReport"); //添加列名 foreach (DataColumn col in ds.Tables[0].Columns) { Type dataType = col.DataType; string ColmString = "{\"ColmCols\":\"" + col.ColumnName + "\",\"ColmType\":\"" + dataType.Name + "\"}"; columnNameList.Add(JsonConvert.DeserializeObject(ColmString));//获取到DataColumn列对象的列名 } objJsonResult.code = "1"; objJsonResult.count = 1; objJsonResult.Message = "Sucess!"; objJsonResult.data = ds.Tables[0]; objJsonResult.list = columnNameList; return objJsonResult; } catch (Exception e) { objJsonResult.code = "0"; objJsonResult.count = 0; objJsonResult.Message = "Exception!" + e.ToString(); objJsonResult.data = null; return objJsonResult; } } #endregion } }