From 2d3fc93b131c7aa771e8f7d08a82d5e9b4946eff Mon Sep 17 00:00:00 2001
From: yangle <admin@YINMOU>
Date: 星期四, 29 六月 2023 16:02:39 +0800
Subject: [PATCH] 提料计划运算(缺料) 日志添加自定义名称方法

---
 WebAPI/Controllers/SCGL/日计划管理/JIT_DayPlanPlatFormBillController.cs | 2485 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 2,482 insertions(+), 3 deletions(-)

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

--
Gitblit v1.9.1