From b502fc26362d5c1b4e3e689fe71b5f6cfa1a7af9 Mon Sep 17 00:00:00 2001
From: 王 垚 <1402714037@qq.com>
Date: 星期六, 13 二月 2021 14:03:48 +0800
Subject: [PATCH] 代码上传

---
 src/BLL/Demo.TimedTaskPlugIn/Demo.TimedTaskPlugIn.csproj |    2 
 /dev/null                                                |  756 ----------------------------------
 src/Model/Demo.Model/Model/DayPlanMaterial.cs            |    4 
 src/BLL/Demo.TimedTaskPlugIn/PRD/TLPlanTimeTask.cs       |  476 +++++++++++++++++++++
 src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs        |   53 +
 5 files changed, 524 insertions(+), 767 deletions(-)

diff --git a/src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs b/src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs
index c0e6ba3..09c553b 100644
--- a/src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs
+++ b/src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs
@@ -1,4 +1,5 @@
-锘縰sing Demo.Model.Model;
+锘縰sing Demo.BillView.PRD;
+using Demo.Model.Model;
 using Demo.Model.Model.PODemandPlan;
 using K3Cloud.Extend.Utils;
 using Kingdee.BOS.Core;
@@ -380,7 +381,7 @@
             //{
             //閿佸畾鍚庣敓鎴愭棩璁″垝鐢ㄦ枡娓呭崟 鍙� 鎻愭枡璁″垝
             DayPlanPPBomBillBatch();
-            Extraction();
+            //Extraction();
             SearchList();
             this.View.ShowMessage("鎿嶄綔鎴愬姛");
             //}
@@ -1713,18 +1714,45 @@
 
         /// <summary>
         /// 鏃ヨ鍒掔敤鏂欐竻鍗曠敓鎴�
-        /// </summary>
+        /// </summary>  
         public void DayPlanPPBomBillBatch()
         {
+            //LogService.WriteAsync(entrys);
+            //鏌ユ壘鍒扮殑鍚屾壒椤规
+            Entity entity = this.View.BillBusinessInfo.GetEntity("FEntity");
+            //鍗曟嵁浣撲俊鎭浆鎹负鍒楄〃闆嗗悎
+            DynamicObjectCollection entityDataObjoct = this.View.Model.GetEntityDataObject(entity);
+            DynamicObjectCollection filterResult = entityDataObjoct.Clone();
+            filterResult.Clear();
+            entityDataObjoct.Where(x => Convert.ToBoolean(x["FFOCUS"])).ToList().ForEach(x => filterResult.Add(x));
+            string sqlWhere = " 1=1 ";
+            string FDayPlanWorkID = "";
+            string zxSql = "";
+            List<string> zxSqlList = new List<string>();
+            if (filterResult.Count() > 0)
+            {
+                foreach (var filter in filterResult)
+                {
+                    FDayPlanWorkID += filter["FDayPlanWorkID"].ToString() + ",";
+                    zxSqlList.Add(string.Format(@"/*dialect*/  
+ INSERT INTO Z_SC_TLPLANZXJH (COLUMN1) VALUES ('{0}') 
+ SELECT * FROM Z_SC_TLPLANZXJH
+ INSERT INTO SC_TLPLANZXJH(FID, FDAYPLANID, FCREATEDATE) SELECT *, GETDATE() FROM Z_SC_TLPLANZXJH
+ DELETE FROM Z_SC_TLPLANZXJH
+ SELECT * FROM SC_TLPLANZXJH", filter["FDayPlanWorkID"]));
+                }
+                FDayPlanWorkID = FDayPlanWorkID.TrimEnd(',');
+                sqlWhere += $"AND t2.FID IN ({FDayPlanWorkID})";
+            }
+            DBServiceHelper.ExecuteBatch(Context, zxSqlList);
             Stopwatch sw = new Stopwatch();
             sw.Start();//寮�濮嬭鏃�
             LogHelper.Info("鐢熸垚鏃ヨ鍒掔敤鏂欐竻鍗曞噯澶囨暟鎹�");
             //閿佸畾鐨勬棩璁″垝涓嶇敓鎴�
             try
             {
-                string sql = string.Format(@"
-/*dialect*/
-select t1.FID,t1.FSEQ FDayPlanFSEQ,t1.FEntryID,T2.FBILLNO AS FDayPlanFBILLNO,t3.FMATERIALID,T5.FNUMBER,t1.FHMASTERDATE,t1.FHQTY,t4.FMATERIALID FMATERIALID2,T6.FNUMBER FNUMBER2,T7.FNUMBER FUNITNUMBER,FNumerator,FDenominator,convert(decimal(18,2),(t4.FMustQty/T3.FQTY) *t1.FHQTY) FHQtyMust,T4.FUnitID,t8.FNUMBER FUNITNUMBER2,T3.FID FPPBOM,T4.FENTRYID FPPBOMENTRYID,isnull(T9.FBillNo,'')FBillNo,t10.FNUMBER FORGNUMBER,t11.FNUMBER FHSOURCENUMBER,FSCRAPRATE,FFIXSCRAPQTY,T9.FID AS DayPlanFID,t2.FSCORDERNO,
+                string sql = string.Format(@"/*dialect*/
+select t1.FID,t1.FSEQ FDayPlanFSEQ,t1.FEntryID,T2.FBILLNO AS FDayPlanFBILLNO,t3.FMATERIALID,t3.FMOEntrySeq as FMoSeq,T5.FNUMBER,t1.FHMASTERDATE,t1.FHQTY,t4.FMATERIALID FMATERIALID2,T6.FNUMBER FNUMBER2,T7.FNUMBER FUNITNUMBER,FNumerator,FDenominator,convert(decimal(18,2),(t4.FMustQty/T3.FQTY) *t1.FHQTY) FHQtyMust,T4.FUnitID,t8.FNUMBER FUNITNUMBER2,T3.FID FPPBOM,T4.FENTRYID FPPBOMENTRYID,isnull(T9.FBillNo,'')FBillNo,t10.FNUMBER FORGNUMBER,t11.FNUMBER FHSOURCENUMBER,FSCRAPRATE,FFIXSCRAPQTY,T9.FID AS DayPlanFID,t2.FSCORDERNO,
 t3.FMOENTRYID,t3.FBILLNO FPPBOMBILLNO,T4.FSEQ,tc.FOWNERTYPEID,tc.FOWNERID,tc.FEntrustPickOrgId,torg.FNUMBER as FORGNUMBER,t3.FMOID,FIssueType,FMaterialType,td.FNUMBER as FWORKSHOPID,t4.FReplaceGroup,isnull(ttt.FrowCount,0)FIsTDL,t4.FUseRate
 FROM Sc_WorkBillSortBillSub t1
 JOIN Sc_WorkBillSortBillMAIN t2 on t1.FID = t2.FID
@@ -1751,12 +1779,13 @@
 select distinct FDAYPLANFID from Sc_DayPlanPPBomBillMain where FID IN (
 select distinct FDAYPLANFID from T_PRD_PICKMTRLDATA)
 )
+AND {0}
 -- and T4.FMustQty>0
 -- (
 -- select  FDayPlanFID FROM Sc_DayPlanPPBomBillMain WHERE FID IN ( select distinct FID from  Sc_DayPlanPPBomBillSub WHERE FTranslateQty >0 or FPickedQty >0)
 -- )
-"
-);
+",
+sqlWhere);
                 LogHelper.Info("鐢熸垚鏃ヨ鍒掔敤鏂欐竻鍗曞噯澶囨暟鎹畇ql:" + sql);
                 DataSet ds = DBServiceHelper.ExecuteDataSet(Context, sql);
                 DataTable dt = ds.Tables[0];
@@ -1802,7 +1831,8 @@
                             FWORKSHOPID = dr["FWORKSHOPID"].ToString(),
                             FReplaceGroup = dr["FReplaceGroup"].ToString(),
                             FUseRate = dr["FUseRate"].ToString(),
-                            FIsTDL = dr["FIsTDL"].ToString()
+                            FIsTDL = dr["FIsTDL"].ToString(),
+                            FMoSeq = dr["FMoSeq"].ToString(),
                         });
                     }
                     LogHelper.Info($"鏃ヨ鍒掔敤鏂欐竻鍗曪紝鏁版嵁鍑嗗瀹屾垚锛屼繚瀛樺埌Model瀹炰綋锛屾�昏鏁帮細{DayPlanMaterial.Count}锛岃�楁椂锛�" + sw.Elapsed);
@@ -1844,6 +1874,7 @@
                             ModelEnty.Add("FHQtyScrap", _item.FHQtyScrap);//鍙樺姩鎹熻�楃巼%
                             ModelEnty.Add("FMOBILLNO", _item.FMOBILLNO);//  
                             ModelEnty.Add("FMOENTRYIDINT", _item.FMOENTRYID);//  
+                            ModelEnty.Add("FMoSeq", _item.FMoSeq);//  
                             ModelEnty.Add("FPPBOMBILLNO", _item.FPPBOMBILLNO);//  
                             ModelEnty.Add("FPPBOMFSEQINT", _item.FPPBOMFSEQ);//  
                             ModelEnty.Add("FOwnerTypeId", _item.FOwnerTypeId);//  
@@ -1909,6 +1940,7 @@
             catch (Exception ex)
             {
                 LogHelper.Error("鏃ヨ鍒掔敤鏂欐竻鍗�+" + ex.Message.ToString());
+                this.View.ShowErrMessage(ex.Message.ToString());
             }
         }
 
@@ -1953,7 +1985,8 @@
                 LogHelper.Info("[鎻愭枡璁″垝鍑嗗闃舵]鍙敤閲囪喘璁㈠崟鏁版嵁sql锛�" + sql);
                 sql = string.Format(@"
  /*dialect*/
- SELECT T1.FID,FHMATERID,FHMASTERDATE,FHQTY,FCOMPLETECOUNT,FPRDMOMAINID,T2.FENTRYID,T1.FBILLNO, FNeedQty,(FLeadtime+FLeadTtime2)FFIXLEADTIME,t5.FMAXPOQTY,FJITBatch FMINPOQTY,FJITMATERIALGROUP,FJITMaterielDemand,FJITSafeStock,t3.FMATERIALID,t6.FNumber,FHQTY*FNeedQty NeedQty,FHPRDORGID FStockOrgId FROM  SC_WORKBILLSORTBILLMAIN T1 
+ SELECT T1.FID,FHMATERID,FHMASTERDATE,FHQTY,FCOMPLETECOUNT,FPRDMOMAINID,T2.FENTRYID,T1.FBILLNO, FNeedQty,(FLeadtime+FLeadTtime2)FFIXLEADTIME,t5.FMAXPOQTY,FJITBatch FMINPOQTY,FJITMATERIALGROUP,FJITMaterielDemand,FJITSafeStock,t3.FMATERIALID,t6.FNumber,FHQTY*FNeedQty NeedQty,FHPRDORGID FStockOrgId
+FROM  SC_WORKBILLSORTBILLMAIN T1 
 JOIN SC_WORKBILLSORTBILLSUB T2 ON T1.FID=T2.FID
 LEFT JOIN(SELECT T1.FID,max(t2.FMATERIALID)FMATERIALIDMAIN, max(t2.FMoId)FMoId,MAX(FENTRYID) FENTRYID, SUM(convert(decimal(18, 2), FBASENUMERATOR / FBASEDENOMINATOR))FNeedQty, T1.FMATERIALID from T_PRD_PPBOMENTRY  T1
 JOIN T_PRD_PPBOM   T2 on t1.FID = t2.FID
diff --git a/src/BLL/Demo.TimedTaskPlugIn/Demo.TimedTaskPlugIn.csproj b/src/BLL/Demo.TimedTaskPlugIn/Demo.TimedTaskPlugIn.csproj
index 554f3e9..70b5a35 100644
--- a/src/BLL/Demo.TimedTaskPlugIn/Demo.TimedTaskPlugIn.csproj
+++ b/src/BLL/Demo.TimedTaskPlugIn/Demo.TimedTaskPlugIn.csproj
@@ -149,7 +149,7 @@
   </ItemGroup>
   <ItemGroup>
     <Compile Include="PRD\StockChangeDynamicAlignment.cs" />
-    <Compile Include="PRD\DayPlanChangeDynamicAlignment.cs" />
+    <Compile Include="PRD\TLPlanTimeTask.cs" />
     <Compile Include="PRD\DayPlanPPBomBillTimeTask.cs" />
     <Compile Include="Properties\AssemblyInfo.cs" />
   </ItemGroup>
diff --git a/src/BLL/Demo.TimedTaskPlugIn/PRD/DayPlanChangeDynamicAlignment.cs b/src/BLL/Demo.TimedTaskPlugIn/PRD/DayPlanChangeDynamicAlignment.cs
deleted file mode 100644
index 2aa3928..0000000
--- a/src/BLL/Demo.TimedTaskPlugIn/PRD/DayPlanChangeDynamicAlignment.cs
+++ /dev/null
@@ -1,756 +0,0 @@
-锘�//using System.ComponentModel;
-//using Kingdee.BOS.Contracts;
-//using Kingdee.BOS;
-//using Kingdee.BOS.Core;
-//using Kingdee.BOS.ServiceHelper;
-//using System.Data;
-//using ZD.Cloud.Logger;
-//using Newtonsoft.Json.Linq;
-//using System;
-//using Kingdee.BOS.Util;
-//using System.Linq;
-//using ZD.Cloud.WebApi;
-//using Demo.Model.Model;
-//using Demo.Model.Model.PODemandPlan;
-//using System.Diagnostics;
-//using System.Collections.Generic;
-//using ZD.Share.Common;
-
-//namespace Demo.TimedTaskPlugIn.PRD
-//{
-//    [Description("鏃ヨ鍒掑彂鐢熷彉鍔ㄦ椂鎵ц")]
-//    [HotUpdate]
-//    public class DayPlanChangeDynamicAlignment : Kingdee.BOS.Contracts.IScheduleService
-//    {
-//        CloudClient cloudClient = new CloudClient("http://localhost//k3cloud/");
-//        public Context Context;
-//        List<PRD_Inventory> ListInventory;//搴撳瓨鏄庣粏
-//        List<PRD_Inventory> ListInventoryByStockOrgId;//鐗╂枡鎬诲簱瀛�
-
-//        public void Run(Context ctx, Schedule schedule)
-//        {
-//            try
-//            {
-//                Context = ctx;
-//                int Count = DBServiceHelper.ExecuteScalar<int>(Context, "/*dialect*/ select count(*) from SC_WORKBILLSORTBILLSub where ISNULL(FCOMPLETE,'')=''  ", 0);
-//                if (Count > 0)
-//                {
-//                    CompleteSetAnalysis();
-//                    DayPlanPPBomBill();
-//                    Extraction();
-//                }
-//            }
-//            catch (System.Exception ex)
-//            {
-//                LogHelper.Error(ex.Message.ToString());
-//            }
-//        }
-
-//        /// <summary>
-//        /// 榻愬鍒嗘瀽
-//        /// </summary>
-//        public void CompleteSetAnalysis()
-//        {
-//            try
-//            {
-//                Stopwatch sw = new Stopwatch();
-//                sw.Start();//寮�濮嬭鏃�
-//                //娓呯┖榻愬涓存椂琛�
-//                DBServiceHelper.Execute(Context, "/*dialect*/  delete JIT_MOMaterReadysBill ");
-//                //鏇存柊鐘舵��
-//                DBServiceHelper.Execute(Context, "/*dialect*/  update Sc_WorkBillSortBillsub set FCOMPLETE='' ");
-//                //鑾峰彇褰撳墠鍗虫椂搴撳瓨 鎸夌収鐗╂枡+搴撳瓨缁勭粐+璐т富+搴撳瓨鏁伴噺  
-//                DataSet ds = DBServiceHelper.ExecuteDataSet(Context, @" 
-///*dialect*/ 
-//  select  isnull(a.FBASEQTY,0)-ISNULL(b.FHUseQty,0) FBASEQTY,T1.FStockOrgId,T1.FMATERIALID,a.FOWNERID,c.FNUMBER from 
-//(
-//select a.FHPRDORGID FStockOrgId,T2.FMATERIALID from SC_WORKBILLSORTBILLMAIN a
-//join SC_WORKBILLSORTBILLSub b on a.FID = b.FID
-//join T_PRD_PPBOM T1 on a.FPRDMOMAINID = t1.FMoId and a.FPRDMOENTYID = t1.FMOENTRYID
-//LEFT JOIN(select FID,FMATERIALID from T_PRD_PPBOMENTRY
-//group by FMATERIALID,FID) T2 on T1.FID = t2.FID
-//group by a.FHPRDORGID,T2.FMATERIALID
-//) T1 
-//LEFT JOIN T_STK_Inventory a on T1.FStockOrgId = a.FStockOrgId and T1.FMATERIALID =a.FMATERIALID 
-//LEFT JOIN JIT_MOMaterReadysBill B ON T1.FStockOrgId = b.FHSTOCKORGID and T1.FMATERIALID =b.FHMATERID and a.FOwnerId = b.FOwnerId 
-//LEFT join T_ORG_Organizations c on a.FOWNERID = c.FORGID
-//--where T1.FMATERIALID in (105773)
-//");
-//                ListInventory = ds.ToModelList<PRD_Inventory>();
-//                //鎬诲簱瀛� 鐗╂枡+搴撳瓨缁勭粐+搴撳瓨鏁伴噺
-//                ds = DBServiceHelper.ExecuteDataSet(Context, @" 
-///*dialect*/ 
-// select  sum(isnull(a.FBASEQTY,0)-ISNULL(b.FHUseQty,0))FBASEQTY,T1.FStockOrgId,T1.FMATERIALID from 
-//(
-//select a.FHPRDORGID FStockOrgId,T2.FMATERIALID from SC_WORKBILLSORTBILLMAIN a
-//join SC_WORKBILLSORTBILLSub b on a.FID = b.FID
-//join T_PRD_PPBOM T1 on a.FPRDMOMAINID = t1.FMoId and a.FPRDMOENTYID = t1.FMOENTRYID
-//LEFT JOIN(select FID,FMATERIALID from T_PRD_PPBOMENTRY
-//group by FMATERIALID,FID) T2 on T1.FID = t2.FID
-//group by a.FHPRDORGID,T2.FMATERIALID
-//) T1 
-//LEFT JOIN T_STK_Inventory a on T1.FStockOrgId = a.FStockOrgId and T1.FMATERIALID =a.FMATERIALID 
-//LEFT JOIN JIT_MOMaterReadysBill B ON T1.FStockOrgId = b.FHSTOCKORGID and T1.FMATERIALID =b.FHMATERID
-//--where T1.FMATERIALID in (105773)
-//group by T1.FStockOrgId,T1.FMATERIALID
-//");
-//                ListInventoryByStockOrgId = ds.ToModelList<PRD_Inventory>();
-//                //闇�瑕侀綈濂楀垎鏋愮殑鏁版嵁
-//                string sql = @"
-///*dialect*/
-//select a.FPRDMOMAINID,a.FPRDMOENTYID,a.FID,b.FEntryID,a.FHPRDORGID FStockOrgId,t5.FNUMBER as OrgFnumber,a.FHOrderLev,b.FHQTY,b.FHMASTERDATE,T1.FBillNo,T1.FMOBillNO,T1.FMOEntrySeq,T1.FMoId,T1.FMaterialID,T1.FQty,
-//T2.FMATERIALID FMATERIALID2, T4.FNumber,T2.FNeedQty,FNeedQty/FQty dwyl,(FHQTY-ISNULL(FProductNum,0))*(FNeedQty/FQty) PlanCount  from SC_WORKBILLSORTBILLMAIN a
-//join SC_WORKBILLSORTBILLSub b on a.FID = b.FID
-//join T_PRD_PPBOM T1 on a.FPRDMOMAINID = t1.FMoId and a.FPRDMOENTYID = t1.FMOENTRYID
-//LEFT JOIN(select FID, MAX(FENTRYID) FENTRYID, SUM(FNeedQty) FNeedQty, FMATERIALID from T_PRD_PPBOMENTRY
-//group by FMATERIALID, FID ) T2 on T1.FID = t2.FID
-// --LEFT JOIN T_STK_Inventory T3 on t2.FMATERIALID = t3.FMATERIALID
-//JOIN T_BD_MATERIAL T4 on T2.FMATERIALID = T4.FMATERIALID
-//JOIN T_ORG_Organizations t5 on a.FHPRDORGID = t5.FORGID
-//--鏉′欢涓轰粖澶╁線鍚庣殑鏃ヨ鍒� + 浠婂ぉ涔嬪墠鏈叧闂殑鏃ヨ鍒�
-//where (FHEntryCloseDate is null and DATEDIFF(D,GETDATE(),FHMASTERDATE)<0)or DATEDIFF(D,GETDATE(),FHMASTERDATE)>=0
-//ORDER BY b.FHMASTERDATE,a.FHOrderLev 
-//";
-//                ds = DBServiceHelper.ExecuteDataSet(Context, sql);
-//                List<PRD_PPBOM> BomList = ds.ToModelList<PRD_PPBOM>();
-//                //鏃ヨ鍒�+鐢熶骇璁㈠崟瀛愯〃缂栫爜ID
-//                var DatePlanList = BomList.GroupBy(p => new { p.FHMASTERDATE, p.FPRDMOENTYID }).Select(x => new PRD_PPBOM { FHMASTERDATE = x.Key.FHMASTERDATE, FPRDMOENTYID = x.Key.FPRDMOENTYID }).ToList();
-//                //CompleteAnalysisTempModel 鐢ㄤ簬瀛樺偍涓存椂闇�瑕佹彃鍏ユ暟鎹�
-//                List<CompleteAnalysisTempModel> completeAnalysisTempModel = new List<CompleteAnalysisTempModel>();
-//                int i = 1;
-//                //鍒涘缓瀛楀吀 鐢ㄤ簬鍌ㄥ瓨鐗╂枡 + 鍗犵敤鏁伴噺
-//                Dictionary<string, decimal> occupyDic = new Dictionary<string, decimal>();
-//                foreach (var item in DatePlanList)
-//                {
-//                    //绛涢�夊嚭褰撴棩璁″垝鏁版嵁
-//                    var _BomList = BomList.Where(x => x.FHMASTERDATE == item.FHMASTERDATE && x.FPRDMOENTYID == item.FPRDMOENTYID).ToList();
-//                    foreach (var _item in _BomList)
-//                    {
-//                        //璇ユ棩璁″垝鐗╂枡闇�瑕佹暟
-//                        decimal need = _item.PlanCount;
-//                        var sjkcList = ListInventoryByStockOrgId.Where(x => x.FMATERIALID == _item.FMATERIALID2 && x.FStockOrgId == _item.FStockOrgId).FirstOrDefault();
-//                        //鐪熸闇�瑕佸彇璁$畻鐨勬暟閲忥紙鎷嗗垎璐т富锛�
-//                        //璐т富鍖归厤
-//                        List<PRD_Inventory> _ListInventory = ListInventory.Where(c => c.FMATERIALID == _item.FMATERIALID2 && c.FStockOrgId == _item.FStockOrgId && c.FBASEQTY > 0).ToList();
-//                        if (_ListInventory.Count > 0)
-//                        {
-//                            decimal _fLackCount = _item.PlanCount > sjkcList.FBASEQTY ? (_item.PlanCount - sjkcList.FBASEQTY) : 0;//缂烘枡鏁伴噺
-//                            foreach (var Inventory in _ListInventory)
-//                            {
-
-//                                if (need == 0)
-//                                    break;
-//                                decimal fCompleteCount = need >= Inventory.FBASEQTY ? Inventory.FBASEQTY : need;//榻愬鏁伴噺
-//                                decimal occupyMaterial = 0;
-//                                if (!occupyDic.ContainsKey(_item.FMATERIALID2))
-//                                {
-//                                    occupyDic.Add(_item.FMATERIALID2, fCompleteCount);
-//                                }
-//                                else
-//                                {
-//                                    occupyMaterial = occupyDic[_item.FMATERIALID2];
-//                                    occupyDic[_item.FMATERIALID2] = occupyMaterial + fCompleteCount;
-//                                }
-//                                completeAnalysisTempModel.Add(new Demo.Model.Model.CompleteAnalysisTempModel
-//                                {
-//                                    FHMainICMOInterIDr = _item.FPRDMOMAINID,
-//                                    FHMainICMOEntryID = _item.FPRDMOENTYID,
-//                                    FHICMOInterID = _item.FID.ToString(),
-//                                    FHICMOEntryID = _item.FEntryID.ToString(),
-//                                    FHMaterID = _item.FNumber,
-//                                    FHStockOrgID = _item.OrgFnumber,
-//                                    FHPRDORGID = _item.OrgFnumber,
-//                                    FPRDBillNo = _item.FMOBillNO,
-//                                    FOwnerTypeId = "BD_OwnerOrg",
-//                                    FOwnerId = Inventory.Fnumber,
-//                                    FUnitDosage = _item.dwyl.ToString(),//鍗曚綅鐢ㄩ噺
-//                                    FSumPlanCount = _item.PlanCount.ToString(),//璁″垝鎬绘暟閲�
-//                                    FCompleteCount = fCompleteCount, //榻愬鏁伴噺
-//                                    FLackCount = _fLackCount,//缂烘枡鏁伴噺
-//                                    FHStockQty = sjkcList.FBASEQTY,//鍗虫椂搴撳瓨
-//                                    FHLeftQty = Inventory.FBASEQTY,//鍙敤鏁伴噺
-//                                    FOccupyCount = occupyMaterial,//鍗犵敤鏁伴噺
-//                                    FComPlete = sjkcList.FBASEQTY >= _item.PlanCount ? "榻愬" : "鏈綈濂�",
-//                                    FPlanDate = item.FHMASTERDATE // 鏃ヨ鍒掓棩鏈�
-//                                });
-//                                //鎵e噺鎬诲簱瀛樻暟閲�
-//                                sjkcList.FBASEQTY = sjkcList.FBASEQTY >= fCompleteCount ? sjkcList.FBASEQTY - fCompleteCount : 0;
-//                                //鍓╀綑鏃ヨ鍒掗渶姹傛暟閲�
-//                                need = need >= Inventory.FBASEQTY ? need - Inventory.FBASEQTY : 0;
-//                                //鎵e噺娑堣�楀簱瀛�
-//                                Inventory.FBASEQTY = Inventory.FBASEQTY - fCompleteCount;
-//                            }
-//                        }
-//                        else
-//                        {
-//                            decimal occupyMaterial = 0;
-//                            if (occupyDic.ContainsKey(_item.FMATERIALID2))
-//                                occupyMaterial = occupyDic[_item.FMATERIALID2];
-//                            completeAnalysisTempModel.Add(new Demo.Model.Model.CompleteAnalysisTempModel
-//                            {
-//                                FHMainICMOInterIDr = _item.FPRDMOMAINID,
-//                                FHMainICMOEntryID = _item.FPRDMOENTYID,
-//                                FHICMOInterID = _item.FID.ToString(),
-//                                FHICMOEntryID = _item.FEntryID.ToString(),
-//                                FHMaterID = _item.FNumber,
-//                                FHStockOrgID = _item.OrgFnumber,
-//                                FHPRDORGID = _item.OrgFnumber,
-//                                FPRDBillNo = _item.FMOBillNO,
-//                                FOwnerTypeId = "BD_OwnerOrg",
-//                                FUnitDosage = _item.dwyl.ToString(),//鍗曚綅鐢ㄩ噺
-//                                FSumPlanCount = _item.PlanCount.ToString(),//璁″垝鎬绘暟閲�
-//                                FCompleteCount = 0, //榻愬鏁伴噺
-//                                FLackCount = _item.PlanCount,//缂烘枡鏁伴噺
-//                                FHStockQty = 0,//鍗虫椂搴撳瓨
-//                                FHLeftQty = 0,//鍙敤鏁伴噺
-//                                FOccupyCount = occupyMaterial,//鍗犵敤鏁伴噺
-//                                FComPlete = "鏈綈濂�",
-//                                FPlanDate = item.FHMASTERDATE // 鏃ヨ鍒掓棩鏈�
-//                            });
-//                        }
-//                    }
-//                    //Thread.Sleep(100);
-//                    i++;
-//                }
-//                i = 1;
-//                foreach (var item in completeAnalysisTempModel)
-//                {
-//                    // this.View.Session["ProcessRateValue"] = Convert.ToInt32(this.View.Session["ProcessRateValue"]) + Convert.ToInt32(1 / completeAnalysisTempModel.Count * 90);
-//                    JObject jsonRoot = new JObject();
-//                    jsonRoot.Add("Creator", "");
-//                    jsonRoot.Add("NeedUpDateFields", new JArray());
-//                    jsonRoot.Add("NeedReturnFields", new JArray());
-//                    jsonRoot.Add("IsDeleteEntry", "true");
-//                    jsonRoot.Add("SubSystemId", "");
-//                    jsonRoot.Add("IsVerifyBaseDataField", "");
-//                    JObject jsonModel = new JObject();
-//                    jsonModel.Add("FHMainICMOInterIDr", item.FHMainICMOInterIDr);
-//                    jsonModel.Add("FHMainICMOEntryID", item.FHMainICMOEntryID);
-//                    jsonModel.Add("FHICMOInterID", item.FHICMOInterID);
-//                    jsonModel.Add("FHICMOEntryID", item.FHICMOEntryID);
-//                    jsonModel.Add("FHMaterID", new JObject() { ["FNUMBER"] = item.FHMaterID });
-//                    jsonModel.Add("FHUseQty", item.FHUseQty);
-//                    jsonModel.Add("FHStockOrgID", new JObject() { ["FNUMBER"] = item.FHStockOrgID });
-//                    jsonModel.Add("FHStockQty", item.FHStockQty);
-//                    jsonModel.Add("FHLeftQty", item.FHLeftQty);
-//                    jsonModel.Add("FHPRDORGID", new JObject() { ["FNUMBER"] = item.FHStockOrgID });
-//                    jsonModel.Add("FUnitDosage", item.FUnitDosage);
-//                    jsonModel.Add("FSumPlanCount", item.FSumPlanCount);
-//                    jsonModel.Add("FCompleteCount", item.FCompleteCount);
-//                    jsonModel.Add("FPRDBillNo", item.FPRDBillNo);
-//                    jsonModel.Add("FOwnerTypeId", item.FOwnerTypeId);
-//                    jsonModel.Add("FComPlete", item.FComPlete);
-//                    jsonModel.Add("FLackCount", item.FLackCount);
-//                    jsonModel.Add("FOccupyCount", item.FOccupyCount);
-//                    jsonModel.Add("FPlanDate", item.FPlanDate);
-//                    if (item.FOwnerId != null)
-//                        jsonModel.Add("FOwnerId", new JObject() { ["FNUMBER"] = item.FOwnerId });
-//                    jsonRoot.Add("Model", jsonModel);
-//                    var result = cloudClient.Save("paez_CompleteAnalysisTemp", jsonRoot.ToString());
-//                    JObject saveObj = JObject.Parse(result);
-//                    string saveIsSuc = saveObj["Result"]["ResponseStatus"]["IsSuccess"].ToString().ToUpper();
-//                    if (saveIsSuc != "TRUE")
-//                    {
-//                        LogHelper.Error(jsonRoot.ToString());
-//                    }
-//                    i++;
-//                }
-//                //鎵ц瀹屾垚鍚� 鏇存柊鏃ヨ鍒掑伐鍗曠姸鎬�
-//                DBServiceHelper.Execute(Context, @"
-///*dialect*/update Sc_WorkBillSortBillSub set FComplete = '鏈綈濂�' where FEntryID IN (select distinct FHICMOEntryID from JIT_MOMaterReadysBill where isnull(FCOMPLETE,'鏈綈濂�') ='鏈綈濂�')
-//");
-//                DBServiceHelper.Execute(Context, @"
-///*dialect*/update Sc_WorkBillSortBillSub set FComplete = '榻愬' where FEntryID NOT IN (select distinct FHICMOEntryID from JIT_MOMaterReadysBill where isnull(FCOMPLETE,'鏈綈濂�') ='鏈綈濂�')
-//");
-//                sw.Stop();//缁撴潫璁℃椂
-//                LogHelper.Info("杩愯鎬绘椂闀匡細" + sw.Elapsed);
-//            }
-//            catch (Exception ex)
-//            {
-//                LogHelper.Error(ex.Message.ToString());
-//            }
-//        }
-
-//        /// <summary>
-//        /// 鏃ヨ鍒掔敤鏂欐竻鍗曠敓鎴�
-//        /// </summary>
-//        public void DayPlanPPBomBill()
-//        {
-//            //閿佸畾鐨勬棩璁″垝涓嶇敓鎴�
-//            try
-//            {
-//                string sql = string.Format(@"
-///*dialect*/
-//select t1.FID,t1.FEntryID,t3.FMATERIALID,T5.FNUMBER,t1.FHMASTERDATE,t1.FHQTY,t4.FMATERIALID FMATERIALID2,T6.FNUMBER FNUMBER2,T7.FNUMBER FUNITNUMBER,FNumerator,FDenominator,convert(decimal(18,2),(FNumerator/FDenominator) *t1.FHQTY) FHQtyMust,T4.FUnitID,t8.FNUMBER FUNITNUMBER2,T3.FID FPPBOM,T4.FENTRYID,isnull(T9.FBillNo,'')FBillNo,t10.FNUMBER FORGNUMBER,t11.FNUMBER FHSOURCENUMBER,FSCRAPRATE,FFIXSCRAPQTY,T9.FID AS DayPlanFID
-//FROM Sc_WorkBillSortBillSub t1
-//JOIN Sc_WorkBillSortBillMAIN t2 on t1.FID = t2.FID
-//JOIN T_PRD_PPBOM T3 on T2.FPRDMOMAINID=t3.FMOID AND T2.FPRDMOENTYID=T3.FMOENTRYID
-//JOIN T_PRD_PPBOMENTRY T4 ON T3.FID=T4.FID
-//JOIN T_BD_MATERIAL T5 ON T3.FMATERIALID=T5.FMATERIALID
-//JOIN T_BD_MATERIAL T6 ON T4.FMATERIALID=T6.FMATERIALID
-//LEFT JOIN T_BD_UNIT T7 ON T3.FUNITID = T7.FUNITID
-//LEFT JOIN T_BD_UNIT T8 ON T4.FUNITID = T8.FUNITID
-// LEFT JOIN Sc_DayPlanPPBomBillMain T9 ON T1.FEntryID=T9.FDayPlanFID
-// LEFT join T_ORG_Organizations t10 on t2.FHPRDORGID = t10.FORGID
-// LEFT join T_ENG_WORKCENTER t11 on t2.FHSOURCEID = t11.FID
-//"
-//);
-//                DataSet ds = DBServiceHelper.ExecuteDataSet(Context, sql);
-//                DataTable dt = ds.Tables[0];
-//                List<DayPlanMaterial> DayPlanMaterial = new List<DayPlanMaterial>();
-//                if (dt.Rows.Count > 0)
-//                {
-//                    foreach (DataRow dr in dt.Rows)
-//                    {
-//                        DayPlanMaterial.Add(new Demo.Model.Model.DayPlanMaterial
-//                        {
-//                            FID = dr["DayPlanFID"].ToString(),
-//                            FEntryID = dr["FEntryID"].ToString(),
-//                            FHDate = DateTime.Now.ToString(),
-//                            FOrgId = dr["FORGNUMBER"].ToString(),
-//                            FHMaterID = dr["FNUMBER"].ToString(),
-//                            FHWorkDate = dr["FHMASTERDATE"].ToString(),
-//                            FHQty = dr["FHQTY"].ToString(),
-//                            FHUnitID = dr["FUNITNUMBER"].ToString(),
-//                            FDayPlanFID = dr["FEntryID"].ToString(),
-//                            FHMaterSubID = dr["FNUMBER2"].ToString(),
-//                            FHUnitSubID = dr["FUNITNUMBER2"].ToString(),
-//                            FHQtyMust = dr["FHQtyMust"].ToString(),
-//                            FHQtySub = dr["FHQtyMust"].ToString(),
-//                            FHPPBomInterID = dr["FPPBOM"].ToString(),
-//                            FHPPBomEntryID = dr["FENTRYID"].ToString(),
-//                            FHSourceID = dr["FHSOURCENUMBER"].ToString(),
-//                            FNumerator = dr["FNumerator"].ToString(),
-//                            FDenominator = dr["FDenominator"].ToString(),
-//                            FFIXSCRAPQTY = dr["FFIXSCRAPQTY"].ToString(),
-//                            FHQtyScrap = dr["FSCRAPRATE"].ToString(),
-//                        });
-//                    }
-//                    var fidList = DayPlanMaterial.Select(x => x.FEntryID).Distinct().ToList();
-//                    foreach (var item in fidList)
-//                    {
-//                        var _DayPlanMaterial = DayPlanMaterial.Where(x => x.FEntryID == item).ToList();
-//                        JObject model = new JObject();
-//                        model.Add("FHDate", DateTime.Now);
-//                        model.Add("FOrgId", new JObject() { ["Fnumber"] = _DayPlanMaterial[0].FOrgId });//鍙戞枡缁勭粐
-//                        model.Add("FHMaterID", new JObject() { ["Fnumber"] = _DayPlanMaterial[0].FHMaterID });//鐗╂枡
-//                        model.Add("FHWorkDate", _DayPlanMaterial[0].FHWorkDate);//鏃ュ伐鍗曟棩鏈� FHWorkDate
-//                        model.Add("FHQty", _DayPlanMaterial[0].FHQty);//涓讳骇鍝佹暟閲忥細FHQty 
-//                        model.Add("FHUnitID", new JObject() { ["Fnumber"] = _DayPlanMaterial[0].FHUnitID });//鍗曚綅锛欶HUnitID 
-//                        model.Add("FDayPlanFID", _DayPlanMaterial[0].FDayPlanFID);//鏃ヨ鍒掑伐鍗曞唴鐮� 
-//                        JArray Entry = new JArray();
-//                        foreach (var _item in _DayPlanMaterial)
-//                        {
-//                            JObject ModelEnty = new JObject();
-//                            ModelEnty.Add("FHMaterSubID", new JObject() { ["Fnumber"] = _item.FHMaterSubID });//瀛愮墿鏂橣HMaterSubID
-//                            ModelEnty.Add("FHUnitSubID", new JObject() { ["Fnumber"] = _item.FHUnitSubID });//鍗曚綅FHUnitSubID
-//                            ModelEnty.Add("FHQtyMust", _item.FHQtyMust);//搴斿彂鏁伴噺FHQtyMust
-//                            ModelEnty.Add("FHQtySub", _item.FHQtySub);//鏁伴噺FHQtySub
-//                            ModelEnty.Add("FHPPBomInterID", _item.FHPPBomInterID);//鐢ㄦ枡娓呭崟涓诲唴鐮丗HPPBomInterID
-//                            ModelEnty.Add("FHPPBomEntryID", _item.FHPPBomEntryID);//鐢ㄦ枡娓呭崟瀛愬唴鐮丗HPPBomEntryID
-//                            ModelEnty.Add("FHSourceID", new JObject() { ["Fnumber"] = _item.FHSourceID });//鐢熶骇璧勬簮FHSourceID
-//                            ModelEnty.Add("FNumerator", _item.FNumerator);//鍒嗘瘝
-//                            ModelEnty.Add("FDenominator", _item.FDenominator);//鍒嗗瓙
-//                            ModelEnty.Add("FDwyl", Convert.ToDecimal(_item.FNumerator) / Convert.ToDecimal(_item.FDenominator));//鍗曚綅鐢ㄦ枡
-//                            ModelEnty.Add("FFIXSCRAPQTY", _item.FFIXSCRAPQTY);//鍥哄畾鎹熻��
-//                            ModelEnty.Add("FHQtyScrap", _item.FHQtyScrap);//鍙樺姩鎹熻�楃巼%
-//                            Entry.Add(ModelEnty);
-//                        }
-//                        model.Add("FEntity", Entry);
-//                        if (!string.IsNullOrEmpty(_DayPlanMaterial[0].FID))
-//                            model.Add("FID", _DayPlanMaterial[0].FID);
-//                        JObject jsonRoot = new JObject()
-//                        {
-//                            ["Creator"] = "",
-//                            ["NeedUpDateFields"] = new JArray(),
-//                            ["NeedReturnFields"] = new JArray(),
-//                            ["IsDeleteEntry"] = "true",
-//                            ["SubSystemId"] = "",
-//                            ["IsVerifyBaseDataField"] = "false",
-//                            ["Model"] = model
-//                        };
-//                        var result = cloudClient.Save("Paez_Sc_DayPlanPPBomBill", jsonRoot.ToString());
-//                        JObject saveObj = JObject.Parse(result);
-//                        string saveIsSuc = saveObj["Result"]["ResponseStatus"]["IsSuccess"].ToString().ToUpper();
-//                        if (saveIsSuc != "TRUE")
-//                            LogHelper.Error(saveIsSuc);
-//                    }
-//                }
-//            }
-//            catch (Exception ex)
-//            {
-//                LogHelper.Error(ex.Message.ToString());
-//            }
-//        }
-//        /// <summary>
-//        /// 鎻愭枡璁″垝
-//        /// </summary>
-//        public void Extraction()
-//        {
-//            string sql = string.Format(@"/*dialect*/ select t1.FID from Sc_WorkBillSortBillMain t1");
-//            DataTable fidDt = DBServiceHelper.ExecuteDataSet(Context, sql).Tables[0];
-//            string FDayPlanWorkID = "";
-//            foreach (DataRow dr in fidDt.Rows)
-//            {
-//                FDayPlanWorkID += Convert.ToString(dr["FID"]) + ",";
-//            }
-//            FDayPlanWorkID = FDayPlanWorkID.Substring(0, FDayPlanWorkID.Length - 1);
-//            //鎻愭枡璁″垝棰勫鐞� 娓呯悊鎻愭枡璁″垝鍗曟暟鎹� 鏇存柊閲囪喘璁㈠崟鎻愭枡璁″垝鏁伴噺
-//            sql = string.Format(@"
-//  /*dialect*/
-// exec [鎻愭枡璁″垝棰勫鐞哴 '{0}'
-// ", FDayPlanWorkID.Replace(",", "-"));
-
-//            DBServiceHelper.Execute(Context, sql);
-//            //閲囪喘璁㈠崟鏁版嵁
-//            sql = @"
-// /*dialect*/
-//select t1.FID,t1.FBillNo,t2.FENTRYID,t1.FSUPPLIERID,t3.fnumber,t2.FMATERIALID,(t2.FQTY-t2.FPODemandPlanCount)FQTY,FPurchaseOrgId FStockOrgId,t5.FNUMBER FORGNumber,FSTOCKINQTY,FReceiveQty,FCloseStatus,FMRPCLOSESTATUS from t_PUR_POOrder t1
-//join t_PUR_POOrderEntry t2 on t1.FID = t2.FID
-//join t_BD_Supplier t3 on t1.FSUPPLIERID = t3.FSUPPLIERID
-//join  T_PUR_POORDERENTRY_R t4 on t2.FENTRYID = t4.FENTRYID
-//join T_ORG_Organizations t5 on t1.FPurchaseOrgId = t5.FORGID
-//where t2.FQTY-t2.FPODemandPlanCount>0
-// and FCloseStatus in('A') and FMRPCLOSESTATUS in('A')
-//";
-//            List<PurchaseInventory> PurchaseInventory = DBServiceHelper.ExecuteDataSet(Context, sql).ToModelList<PurchaseInventory>();
-//            LogHelper.Info("閲囪喘璁㈠崟鏁版嵁" + sql);
-
-//            sql = string.Format(@"
-// /*dialect*/
-// SELECT T1.FID,FHMATERID,FHMASTERDATE,FHQTY,FCOMPLETECOUNT,FPRDMOMAINID,T2.FENTRYID,T1.FBILLNO, FNeedQty,(FLeadtime+FLeadTtime2)FFIXLEADTIME,t5.FMAXPOQTY,FJITBatch FMINPOQTY,FJITMATERIALGROUP,FJITMaterielDemand,FJITSafeStock,t3.FMATERIALID,t6.FNumber,FHQTY*FNeedQty NeedQty,FHPRDORGID FStockOrgId FROM  SC_WORKBILLSORTBILLMAIN T1 
-//JOIN SC_WORKBILLSORTBILLSUB T2 ON T1.FID=T2.FID
-//LEFT JOIN(SELECT T1.FID,max(t2.FMATERIALID)FMATERIALIDMAIN, max(t2.FMoId)FMoId,MAX(FENTRYID) FENTRYID, SUM(convert(decimal(18, 2), FBASENUMERATOR / FBASEDENOMINATOR))FNeedQty, T1.FMATERIALID from T_PRD_PPBOMENTRY  T1
-//JOIN T_PRD_PPBOM   T2 on t1.FID = t2.FID
-//group by T1.FMATERIALID, T1.FID) T3 on T1.FPRDMOMAINID = t3.FMoId  and T1.FHMATERID = t3.FMATERIALIDMAIN
-//JOIN T_BD_MATERIAL T6 ON T3.FMATERIALID = T6.FMATERIALID
-//join t_BD_MaterialBase t4 on t3.FMATERIALID = t4.FMATERIALID
-//join t_BD_MaterialPlan t5 on t3.FMATERIALID = t5.FMATERIALID
-//WHERE  DATEDIFF(D,GETDATE(),FHMASTERDATE) >=0
-//AND FDayPlanQuantity>FCOMPLETECOUNT
-//AND FERPCLSID=1 
-// AND T2.FENTRYID not in (select distinct FHSOURCEENTRYID from CG_PODEMANDPLANBILLSUB where FHSOURCEINTERID IN ({0}))
-//AND T1.FID in ({0}) 
-//order by FHMASTERDATE
-//", FDayPlanWorkID);
-//            LogHelper.Info("鎻愭枡鏁版嵁" + sql);
-//            DataSet ds = DBServiceHelper.ExecuteDataSet(Context, sql);
-//            List<DayPlanPpbom> DayPlanPpbom = ds.ToModelList<DayPlanPpbom>();
-
-//            var MaterialIDList = DayPlanPpbom.GroupBy(p => new { p.FMATERIALID, p.FStockOrgId }).Select(x => new PODemandPlanTemp { FMATERIALID = x.Key.FMATERIALID, FStockOrgId = x.Key.FStockOrgId }).ToList();
-//            var _MaterialIDList = MaterialIDList.Where(p => p.FMATERIALID == "105773").ToList();
-
-//            LogHelper.Info("鐗╂枡琛屾暟" + MaterialIDList.Count);
-
-//            //鎻愭枡璁″垝鏁版嵁闆嗕复鏃跺瓨鍌ㄩ泦鍚�
-//            List<PODemandPlanTemp> PODemandPlanTemp = new List<PODemandPlanTemp>();
-//            //sql闆嗗悎 鏇存柊閲囪喘璁㈠崟鍗犵敤鐨勬彁鏂欒鍒掓暟閲�
-//            List<string> sqlList = new List<string>();
-//            //MaterialIDList = new List<string> { "105773" };
-//            foreach (var item in MaterialIDList)
-//            {
-//                LogHelper.Info(item.FMATERIALID.ToString());
-//                List<DayPlanPpbom> _DayPlanPpbom = DayPlanPpbom.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId).ToList();
-
-//                decimal FMINPOQTY = _DayPlanPpbom.FirstOrDefault().FMINPOQTY;//鏈�灏忚捣璁㈤噺
-//                double FFIXLEADTIME = _DayPlanPpbom.FirstOrDefault().FFIXLEADTIME;//鎻愬墠鏈�
-//                string FJITmaterialGroup = _DayPlanPpbom.FirstOrDefault().FJITmaterialGroup;//jit鐗╂枡鍒嗙被
-//                string FJITMaterielDemand = _DayPlanPpbom.FirstOrDefault().FJITMaterielDemand; //JIT鐗╂枡闇�姹備緵璐у懆鏈�
-//                string FJITSafeStock = _DayPlanPpbom.FirstOrDefault().FJITSafeStock; //JIT瀹夊叏搴撳瓨
-//                decimal NeedQty = 0;
-//                DateTime DATE = _DayPlanPpbom.FirstOrDefault().FHMASTERDATE;
-//                int i = 1;
-//                //璁板綍鍦ㄦ渶灏忛噰璐噺闇�姹備笅鐨勬棩璁″垝鏄庣粏FentyrID
-//                List<int> FEntryIdList = new List<int>();
-//                foreach (var _item in _DayPlanPpbom)
-//                {
-//                    if (NeedQty == 0)
-//                        DATE = Convert.ToDateTime(_item.FHMASTERDATE).AddDays(-FFIXLEADTIME);
-//                    FEntryIdList.Add(_item.FENTRYID);
-//                    NeedQty += _item.NeedQty;
-//                    if ((FJITmaterialGroup == "鎬婚噺鎺у埗瑙勬牸绫�" || FJITmaterialGroup == "璁㈠崟涓撶敤涓�х被") && FEntryIdList.Count < Convert.ToInt32(FJITMaterielDemand)) //璁㈠崟涓撶敤涓�х被
-//                        continue;
-//                    if (NeedQty >= FMINPOQTY)
-//                    {
-//                        List<PurchaseInventory> _PurchaseInventory = PurchaseInventory.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId && x.FQTY > 0).ToList();
-//                        if (_PurchaseInventory.Count == 0)
-//                        {
-//                            NeedQty = 0;
-//                            break;
-//                        }
-//                        foreach (var Purchase in _PurchaseInventory)
-//                        {
-//                            LogHelper.Info("Purchase");
-//                            LogHelper.Info("鐗╂枡锛�" + Purchase.FMATERIALID + ",鏁伴噺锛�" + Purchase.FQTY);
-//                            if (Purchase.FQTY >= NeedQty)
-//                            {
-//                                List<int> mmm = new List<int>();
-//                                foreach (int id in FEntryIdList)
-//                                {
-//                                    mmm.Add(id);
-//                                    var DayPlanPpbomls = DayPlanPpbom.Where(c => c.FENTRYID == id && c.FMATERIALID == _item.FMATERIALID).FirstOrDefault();
-//                                    PODemandPlanTemp.Add(new Demo.Model.Model.PODemandPlan.PODemandPlanTemp
-//                                    {
-//                                        FID = DayPlanPpbomls.FID,
-//                                        FHMASTERDATE = DATE,
-//                                        FQty = DayPlanPpbomls.NeedQty,
-//                                        FBILLNO = DayPlanPpbomls.FBILLNO,
-//                                        FENTRYID = DayPlanPpbomls.FENTRYID,
-//                                        FMATERIALID = DayPlanPpbomls.FMATERIALID,
-//                                        FNumber = DayPlanPpbomls.FNumber,
-//                                        OLDDATE = DayPlanPpbomls.FHMASTERDATE,
-//                                        FFIXLEADTIME = FFIXLEADTIME,
-
-//                                        PurchseFID = Purchase.FID,
-//                                        PurchseFentryID = Purchase.FENTRYID,
-//                                        FSUPPLIERID = Purchase.FSUPPLIERID,
-//                                        PurchseFNUMBER = Purchase.FNUMBER,
-//                                        PurchseFBillNo = Purchase.FBillNo,
-//                                        PurchseFqty = Purchase.FQTY,
-//                                        FStockOrgId = Purchase.FStockOrgId, //閲囪喘缁勭粐
-//                                        FORGNumber = Purchase.FORGNumber
-//                                    });
-//                                    //鎵i櫎鏃ヨ鍒掓槑缁嗗凡琚垎閰嶇殑鏁伴噺
-//                                    DayPlanPpbomls.NeedQty = 0;
-//                                }
-//                                FEntryIdList.Clear();
-//                                //鏇存柊閲囪喘璁㈠崟
-//                                sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount  =isnull(FPODemandPlanCount,0)+  '{NeedQty}' where FENTRYID = {Purchase.FENTRYID}");
-//                                //鎵i櫎褰撳墠琛屽搴旈噰璐鍗曟暟閲�
-//                                var ls = PurchaseInventory.Where(c => c.FENTRYID == Purchase.FENTRYID).FirstOrDefault();
-//                                ls.FQTY -= NeedQty;
-//                                break;
-//                            }
-//                            else
-//                            {
-//                                NeedQty = NeedQty - Purchase.FQTY;
-//                                decimal _NeedQty = Purchase.FQTY;//閲囪喘璁㈠崟鏁伴噺
-//                                List<int> mmm = new List<int>();
-//                                foreach (int id in FEntryIdList)
-//                                {
-//                                    var DayPlanPpbomls = DayPlanPpbom.Where(c => c.FENTRYID == id && c.FMATERIALID == _item.FMATERIALID).FirstOrDefault();
-//                                    decimal Qty = DayPlanPpbomls.NeedQty;
-//                                    if (Qty > _NeedQty)
-//                                        Qty = _NeedQty;
-//                                    _NeedQty = _NeedQty - DayPlanPpbomls.NeedQty;
-//                                    PODemandPlanTemp.Add(new Demo.Model.Model.PODemandPlan.PODemandPlanTemp
-//                                    {
-//                                        FID = DayPlanPpbomls.FID,
-//                                        FHMASTERDATE = DATE,
-//                                        FQty = Qty,
-//                                        FBILLNO = DayPlanPpbomls.FBILLNO,
-//                                        FENTRYID = DayPlanPpbomls.FENTRYID,
-//                                        FMATERIALID = DayPlanPpbomls.FMATERIALID,
-//                                        FNumber = DayPlanPpbomls.FNumber,
-//                                        OLDDATE = DayPlanPpbomls.FHMASTERDATE,
-//                                        FFIXLEADTIME = FFIXLEADTIME,
-
-//                                        PurchseFID = Purchase.FID,
-//                                        PurchseFentryID = Purchase.FENTRYID,
-//                                        FSUPPLIERID = Purchase.FSUPPLIERID,
-//                                        PurchseFNUMBER = Purchase.FNUMBER,
-//                                        PurchseFBillNo = Purchase.FBillNo,
-//                                        PurchseFqty = Purchase.FQTY,
-//                                        FStockOrgId = Purchase.FStockOrgId, //閲囪喘缁勭粐
-//                                        FORGNumber = Purchase.FORGNumber
-//                                    });
-//                                    DayPlanPpbomls.NeedQty -= Qty;
-//                                    //鏇存柊閲囪喘璁㈠崟
-//                                    sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount = isnull(FPODemandPlanCount,0)+ '{Qty}' where FENTRYID = {Purchase.FENTRYID}");
-//                                    //鏇存柊Model
-//                                    var ls = PurchaseInventory.Where(c => c.FENTRYID == Purchase.FENTRYID).FirstOrDefault();
-//                                    ls.FQTY -= Qty;
-//                                    if (_NeedQty < 0)
-//                                    {
-//                                        foreach (var mm in mmm)
-//                                        {
-//                                            FEntryIdList.Remove(mm);
-//                                        }
-//                                        break;
-//                                    }
-//                                    mmm.Add(id);
-//                                }
-//                                foreach (var mm in mmm)
-//                                {
-//                                    FEntryIdList.Remove(mm);
-//                                }
-//                            }
-//                        }
-//                        NeedQty = 0;
-//                    }
-
-//                    #region 鍓╀笅涓嶈冻鏃舵寜鏈�灏忛噰璐壒娆$敓鎴�
-//                    //鍓╀笅涓嶈冻鏃舵寜鏈�灏忛噰璐壒娆$敓鎴�
-//                    //else if (i == _DayPlanPpbom.Count && NeedQty > 0)
-//                    //{
-//                    //    NeedQty = FMINPOQTY;
-//                    //    List<PurchaseInventory> _PurchaseInventory = PurchaseInventory.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId && x.FQTY > 0).ToList();
-//                    //    if (_PurchaseInventory.Count == 0)
-//                    //    {
-//                    //        NeedQty = 0;
-//                    //        break;
-//                    //    }
-
-//                    //    foreach (var Purchase in _PurchaseInventory)
-//                    //    {
-//                    //        if (Purchase.FQTY >= NeedQty)
-//                    //        {
-
-//                    //            List<int> mmm = new List<int>();
-//                    //            foreach (int id in FEntryIdList)
-//                    //            {
-//                    //                mmm.Add(id);
-//                    //                var DayPlanPpbomls = DayPlanPpbom.Where(c => c.FENTRYID == id && c.FMATERIALID == _item.FMATERIALID).FirstOrDefault();
-//                    //                PODemandPlanTemp.Add(new Demo.Model.Model.PODemandPlan.PODemandPlanTemp
-//                    //                {
-//                    //                    FID = DayPlanPpbomls.FID,
-//                    //                    FHMASTERDATE = DATE,
-//                    //                    FQty = DayPlanPpbomls.NeedQty,
-//                    //                    FBILLNO = DayPlanPpbomls.FBILLNO,
-//                    //                    FENTRYID = DayPlanPpbomls.FENTRYID,
-//                    //                    FMATERIALID = DayPlanPpbomls.FMATERIALID,
-//                    //                    FNumber = DayPlanPpbomls.FNumber,
-//                    //                    OLDDATE = DayPlanPpbomls.FHMASTERDATE,
-//                    //                    FFIXLEADTIME = FFIXLEADTIME,
-
-//                    //                    PurchseFID = Purchase.FID,
-//                    //                    PurchseFentryID = Purchase.FENTRYID,
-//                    //                    FSUPPLIERID = Purchase.FSUPPLIERID,
-//                    //                    PurchseFNUMBER = Purchase.FNUMBER,
-//                    //                    PurchseFBillNo = Purchase.FBillNo,
-//                    //                    PurchseFqty = Purchase.FQTY
-
-//                    //                });
-//                    //                //鎵i櫎鏃ヨ鍒掓槑缁嗗凡琚垎閰嶇殑鏁伴噺
-//                    //                DayPlanPpbomls.NeedQty = 0;
-//                    //            }
-//                    //            FEntryIdList.Clear();
-//                    //            //鏇存柊閲囪喘璁㈠崟
-//                    //            sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount  =isnull(FPODemandPlanCount,0)+  '{NeedQty}' where FENTRYID = {Purchase.FENTRYID}");
-//                    //            //鎵i櫎褰撳墠琛屽搴旈噰璐鍗曟暟閲�
-//                    //            var ls = PurchaseInventory.Where(c => c.FENTRYID == Purchase.FENTRYID).FirstOrDefault();
-//                    //            ls.FQTY -= NeedQty;
-//                    //            break;
-//                    //        }
-//                    //        else
-//                    //        {
-//                    //            NeedQty = NeedQty - Purchase.FQTY;
-//                    //            decimal _NeedQty = Purchase.FQTY;//閲囪喘璁㈠崟鏁伴噺
-//                    //            List<int> mmm = new List<int>();
-//                    //            foreach (int id in FEntryIdList)
-//                    //            {
-
-//                    //                var DayPlanPpbomls = DayPlanPpbom.Where(c => c.FENTRYID == id && c.FMATERIALID == _item.FMATERIALID).FirstOrDefault();
-//                    //                decimal Qty = DayPlanPpbomls.NeedQty;
-//                    //                if (Qty > _NeedQty)
-//                    //                    Qty = _NeedQty;
-//                    //                _NeedQty = _NeedQty - DayPlanPpbomls.NeedQty;
-//                    //                PODemandPlanTemp.Add(new Demo.Model.Model.PODemandPlan.PODemandPlanTemp
-//                    //                {
-//                    //                    FID = DayPlanPpbomls.FID,
-//                    //                    FHMASTERDATE = DATE,
-//                    //                    FQty = Qty,
-//                    //                    FBILLNO = DayPlanPpbomls.FBILLNO,
-//                    //                    FENTRYID = DayPlanPpbomls.FENTRYID,
-//                    //                    FMATERIALID = DayPlanPpbomls.FMATERIALID,
-//                    //                    FNumber = DayPlanPpbomls.FNumber,
-//                    //                    OLDDATE = DayPlanPpbomls.FHMASTERDATE,
-//                    //                    FFIXLEADTIME = FFIXLEADTIME,
-
-
-//                    //                    PurchseFID = Purchase.FID,
-//                    //                    PurchseFentryID = Purchase.FENTRYID,
-//                    //                    FSUPPLIERID = Purchase.FSUPPLIERID,
-//                    //                    PurchseFNUMBER = Purchase.FNUMBER,
-//                    //                    PurchseFBillNo = Purchase.FBillNo,
-//                    //                    PurchseFqty = Purchase.FQTY
-
-
-//                    //                });
-//                    //                DayPlanPpbomls.NeedQty -= Qty;
-//                    //                //鏇存柊閲囪喘璁㈠崟
-//                    //                sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount = isnull(FPODemandPlanCount,0)+ '{Qty}' where FENTRYID = {Purchase.FENTRYID}");
-
-//                    //                //鏇存柊Model
-//                    //                var ls = PurchaseInventory.Where(c => c.FENTRYID == Purchase.FENTRYID).FirstOrDefault();
-//                    //                ls.FQTY -= Qty;
-
-//                    //                if (_NeedQty < 0)
-//                    //                {
-//                    //                    foreach (var mm in mmm)
-//                    //                    {
-//                    //                        FEntryIdList.Remove(mm);
-//                    //                    }
-//                    //                    break;
-//                    //                }
-
-//                    //                mmm.Add(id);
-//                    //            }
-//                    //            foreach (var mm in mmm)
-//                    //            {
-//                    //                FEntryIdList.Remove(mm);
-//                    //            }
-
-//                    //        }
-//                    //    }
-//                    //    NeedQty = 0;
-//                    //}
-//                    #endregion
-//                    i++;
-//                }
-//            }
-//            var PODemandPlanList222 = PODemandPlanTemp.GroupBy(p => new PODemandPlanTemp { PurchseFNUMBER = p.PurchseFNUMBER, FHMASTERDATE = p.FHMASTERDATE }).Select(x => new PODemandPlanTemp { PurchseFNUMBER = x.Key.PurchseFNUMBER, FHMASTERDATE = x.Key.FHMASTERDATE }).ToList();
-//            var PODemandPlanList = PODemandPlanTemp.GroupBy(p => new { p.PurchseFNUMBER, p.FHMASTERDATE }).Select(x => new PODemandPlanTemp { PurchseFNUMBER = x.Key.PurchseFNUMBER, FHMASTERDATE = x.Key.FHMASTERDATE }).ToList();
-//            foreach (var item in PODemandPlanList)
-//            {
-//                DateTime date = item.FHMASTERDATE;
-//                string PurchseFNUMBER = item.PurchseFNUMBER;
-//                JObject model = new JObject();
-//                model.Add("FHDate", date);
-//                model.Add("FHRemark", "鐢熶骇璁㈠崟鍙凤細" + "娴嬭瘯鍛㈠憿");
-//                model.Add("FSupplierID", new JObject() { ["Fnumber"] = PurchseFNUMBER });
-//                JArray Fentity = new JArray();
-//                List<PODemandPlanTemp> _PODemandPlanList = PODemandPlanTemp.Where(x => x.FHMASTERDATE == date && x.PurchseFNUMBER == PurchseFNUMBER).ToList();
-//                foreach (var _item in _PODemandPlanList)
-//                {
-//                    JObject FentityModel = new JObject();
-//                    FentityModel.Add("FHPURCHASEORGID", new JObject() { ["Fnumber"] = _item.FORGNumber });//閲囪喘缁勭粐
-//                    FentityModel.Add("FHMaterID", new JObject() { ["Fnumber"] = _item.FNumber });//鐗╂枡
-//                    FentityModel.Add("FHQty", _item.FQty);//鏁伴噺
-//                    FentityModel.Add("FHSourceInterID", _item.FID);//鏃ヨ鍒掑伐鍗旻ID
-//                    FentityModel.Add("FHSourceEntryID", _item.FENTRYID);//鏃ヨ鍒掑伐鍗旻ENTRYID
-//                    FentityModel.Add("FHSourceBillNo", _item.FBILLNO);//鏃ヨ鍒掑伐鍗曞崟鍙�
-//                    FentityModel.Add("FHSourceBillType", "");//鏃ヨ鍒掑伐鍗曠被鍨�
-//                    FentityModel.Add("FDayPlanDate", _item.OLDDATE);//鏃ヨ鍒掑伐鍗曠被鍨�
-//                    FentityModel.Add("FHRelationQty", _item.PurchseFqty);//鍏宠仈鏁伴噺
-//                    FentityModel.Add("FFIXLEADTIME", _item.FFIXLEADTIME);//鎻愬墠鏈�
-
-//                    FentityModel.Add("FPURCHASEORGID", new JObject() { ["Fnumber"] = _item.FORGNumber });//閲囪喘缁勭粐
-//                    FentityModel.Add("FHPOOrderInterID", _item.PurchseFID);// 閲囪喘璁㈠崟鍐呯爜锛欶HPOOrderInterID
-//                    FentityModel.Add("FHPOOrderEntryID", _item.PurchseFentryID); //閲囪喘璁㈠崟瀛愬唴鐮侊細FHPOOrderEntryID
-//                    FentityModel.Add("FHPOOrderBillNo", _item.PurchseFBillNo); //閲囪喘璁㈠崟鍙凤細FHPOOrderBillNo
-//                    Fentity.Add(FentityModel);
-//                }
-//                model.Add("FEntity", Fentity);
-//                JObject jsonRoot = new JObject()
-//                {
-//                    ["Creator"] = "",
-//                    ["NeedUpDateFields"] = new JArray(),
-//                    ["NeedReturnFields"] = new JArray(),
-//                    ["IsDeleteEntry"] = "false",
-//                    ["SubSystemId"] = "",
-//                    ["IsVerifyBaseDataField"] = "false",
-//                    ["Model"] = model
-//                };
-//                var result = cloudClient.Save("paez_PODemandPlan", jsonRoot.ToString());
-//                JObject saveObj = JObject.Parse(result);
-//                string saveIsSuc = saveObj["Result"]["ResponseStatus"]["IsSuccess"].ToString().ToUpper();
-//                LogHelper.Info("鏈�鍚�");
-//                LogHelper.Info(jsonRoot.ToString());
-//                if (saveIsSuc != "TRUE")
-//                    LogHelper.Error(saveIsSuc);
-//            }
-//            DBServiceHelper.ExecuteBatch(Context, sqlList);
-//        }
-//    }
-//}
diff --git a/src/BLL/Demo.TimedTaskPlugIn/PRD/TLPlanTimeTask.cs b/src/BLL/Demo.TimedTaskPlugIn/PRD/TLPlanTimeTask.cs
new file mode 100644
index 0000000..b2a30a7
--- /dev/null
+++ b/src/BLL/Demo.TimedTaskPlugIn/PRD/TLPlanTimeTask.cs
@@ -0,0 +1,476 @@
+锘縰sing System.ComponentModel;
+using Kingdee.BOS.Contracts;
+using Kingdee.BOS;
+using Kingdee.BOS.Core;
+using Kingdee.BOS.ServiceHelper;
+using System.Data;
+using ZD.Cloud.Logger;
+using Newtonsoft.Json.Linq;
+using System;
+using Kingdee.BOS.Util;
+using System.Linq;
+using ZD.Cloud.WebApi;
+using Demo.Model.Model;
+using Demo.Model.Model.PODemandPlan;
+using System.Diagnostics;
+using System.Collections.Generic;
+using ZD.Share.Common;
+
+namespace Demo.TimedTaskPlugIn.PRD
+{
+    [Description("鏃ヨ鍒掑彂鐢熷彉鍔ㄦ椂鎵ц")]
+    [HotUpdate]
+    public class TLPlanTimeTask : Kingdee.BOS.Contracts.IScheduleService
+    {
+        CloudClient cloudClient = new CloudClient("http://localhost//k3cloud/");
+        public Context Context;
+        public void Run(Context ctx, Schedule schedule)
+        {
+            try
+            {
+                Stopwatch sw = new Stopwatch();
+                sw.Start();
+                Context = ctx;
+                string sql = "/*dialect*/  select  FID,FDAYPLANID from sc_TLPLANZXJH where FISZX = 0";
+                List<string> sqlList = new List<string>();
+                DataTable dt = DBServiceHelper.ExecuteDataSet(Context, sql).Tables[0];
+                if (dt.Rows.Count > 0)
+                {
+                    foreach (DataRow dr in dt.Rows)
+                    {
+                        Extraction(dr["FDAYPLANID"].ToString());
+                        sqlList.Add($"/*dialect*/  update sc_TLPLANZXJH set  FZXDATE = getdate(), FISZX = 1 where FID={dr["FID"]}");
+                    }
+                    DBServiceHelper.ExecuteBatch(Context, sqlList);
+                }
+                LogHelper.Info("鎻愭枡璁″垝鏃堕暱锛�" + sw.Elapsed);
+                sw.Stop();
+
+            }
+            catch (System.Exception ex)
+            {
+                LogHelper.Error(ex.Message.ToString());
+            }
+        }
+
+        public void Extraction(string FDayPlanWorkID)
+        {
+            LogHelper.Info("[鎻愭枡璁″垝鍑嗗闃舵]锛氭祴璇曟祴璇曟祴璇曟祴璇曟祴璇曟祴璇曟祴璇曟祴璇�");
+            try
+            {
+                //Stopwatch sw = new Stopwatch();
+                //sw.Start();//寮�濮嬭鏃�
+                //鎻愭枡璁″垝棰勫鐞� 娓呯悊鎻愭枡璁″垝鍗曟暟鎹� 鏇存柊閲囪喘璁㈠崟鎻愭枡璁″垝鏁伴噺
+                string sql = string.Format(@"
+  /*dialect*/
+ exec [鎻愭枡璁″垝棰勫鐞哴 '{0}'
+ ", FDayPlanWorkID.Replace(",", "-"));
+                DBServiceHelper.Execute(Context, sql);
+                LogHelper.Info("[鎻愭枡璁″垝鍑嗗闃舵]鎻愭枡璁″垝棰勫鐞唖ql锛�" + sql);
+                //閲囪喘璁㈠崟鏁版嵁
+                sql = @"
+ /*dialect*/
+ select t1.FID,t1.FBillNo,t2.FENTRYID,t1.FSUPPLIERID,t3.fnumber,t2.FMATERIALID,(t2.FQTY-t2.FPODemandPlanCount)FQTY,FPurchaseOrgId FStockOrgId,t5.FNUMBER FORGNumber,FSTOCKINQTY,FReceiveQty,FCloseStatus,FMRPCLOSESTATUS from t_PUR_POOrder t1
+join t_PUR_POOrderEntry t2 on t1.FID = t2.FID
+join t_BD_Supplier t3 on t1.FSUPPLIERID = t3.FSUPPLIERID
+join  T_PUR_POORDERENTRY_R t4 on t2.FENTRYID = t4.FENTRYID
+join T_ORG_Organizations t5 on t1.FPurchaseOrgId = t5.FORGID
+where t2.FQTY-t2.FPODemandPlanCount>0
+ and FCloseStatus in('A') and FMRPCLOSESTATUS in('A')
+ and t1.FBillTypeID in('83d822ca3e374b4ab01e5dd46a0062bd','6d01d059713d42a28bb976c90a121142')
+";
+                List<PurchaseInventory> PurchaseInventory = DBServiceHelper.ExecuteDataSet(Context, sql).ToModelList<PurchaseInventory>();
+                LogHelper.Info("[鎻愭枡璁″垝鍑嗗闃舵]鍙敤閲囪喘璁㈠崟鏁版嵁sql锛�" + sql);
+                sql = string.Format(@"
+ /*dialect*/
+ SELECT T1.FID,FHMATERID,FHMASTERDATE,FHQTY,FCOMPLETECOUNT,FPRDMOMAINID,T2.FENTRYID,T1.FBILLNO, FNeedQty,(FLeadtime+FLeadTtime2)FFIXLEADTIME,t5.FMAXPOQTY,FJITBatch FMINPOQTY,FJITMATERIALGROUP,FJITMaterielDemand,FJITSafeStock,t3.FMATERIALID,t6.FNumber,FHQTY*FNeedQty NeedQty,FHPRDORGID FStockOrgId
+FROM  SC_WORKBILLSORTBILLMAIN T1 
+JOIN SC_WORKBILLSORTBILLSUB T2 ON T1.FID=T2.FID
+LEFT JOIN(SELECT T1.FID,max(t2.FMATERIALID)FMATERIALIDMAIN, max(t2.FMoId)FMoId,MAX(FENTRYID) FENTRYID, SUM(convert(decimal(18, 2), FBASENUMERATOR / FBASEDENOMINATOR))FNeedQty, T1.FMATERIALID from T_PRD_PPBOMENTRY  T1
+JOIN T_PRD_PPBOM   T2 on t1.FID = t2.FID
+group by T1.FMATERIALID, T1.FID) T3 on T1.FPRDMOMAINID = t3.FMoId  and T1.FHMATERID = t3.FMATERIALIDMAIN
+JOIN T_BD_MATERIAL T6 ON T3.FMATERIALID = T6.FMATERIALID
+join t_BD_MaterialBase t4 on t3.FMATERIALID = t4.FMATERIALID
+join t_BD_MaterialPlan t5 on t3.FMATERIALID = t5.FMATERIALID
+WHERE  DATEDIFF(D,GETDATE(),FHMASTERDATE) >=0
+AND FComplete ='鏈綈濂�'
+AND FERPCLSID=1 
+ AND T2.FENTRYID not in (select distinct FHSOURCEENTRYID from CG_PODEMANDPLANBILLSUB where FHSOURCEINTERID IN ({0}))
+AND T1.FID in ({0}) 
+order by FHMASTERDATE
+", FDayPlanWorkID);
+                sql = string.Format(@"
+ /*dialect*/
+SELECT T1.FID,FHMASTERDATE,t1.FEntryID,T1.FBILLNO, FNeedQty,(FLeadtime+FLeadTtime2)FFIXLEADTIME,t5.FMAXPOQTY,FJITBatch FMINPOQTY,FJITMATERIALGROUP,FJITMaterielDemand,FJITSafeStock,t1.FMATERIALID,t6.FNumber,NeedQty, FStockOrgId ,FErpClsID
+FROM   (
+select FHICMOINTERID FID,FHICMOENTRYID FEntryID,FPlanDate FHMASTERDATE,FLackCount NeedQty,FHMATERID FMATERIALID,FHStockOrgID FStockOrgId,FPRDBILLNO FBillNo,FSumPlanCount FNeedQty from JIT_MOMaterReadysBill a
+right join (select max(FID)FID from JIT_MOMaterReadysBill GROUP BY FHICMOENTRYID,FHMATERID) b on a.FID = b.FID
+)T1
+JOIN T_BD_MATERIAL T6 ON T1.FMATERIALID = T6.FMATERIALID
+join t_BD_MaterialBase t4 on T1.FMATERIALID = t4.FMATERIALID
+join t_BD_MaterialPlan t5 on T1.FMATERIALID = t5.FMATERIALID
+WHERE  DATEDIFF(D,GETDATE(),FHMASTERDATE) >=0
+AND FERPCLSID in ('1','3') 
+AND T1.NeedQty>0
+AND T1.FENTRYID not in (select distinct FHSOURCEENTRYID from CG_PODEMANDPLANBILLSUB where FHSOURCEINTERID IN ({0}))
+AND T1.FID in ({0}) 
+order by FHMASTERDATE
+", FDayPlanWorkID);
+                //LogHelper.Info("[鎻愭枡璁″垝鍑嗗闃舵]闇�瑕佹彁鏂欐暟鎹畇ql锛�" + sql);
+                DataSet ds = DBServiceHelper.ExecuteDataSet(Context, sql);
+                List<DayPlanPpbom> DayPlanPpbom = ds.ToModelList<DayPlanPpbom>();
+                //鐗╂枡+搴撳瓨缁勭粐鍒嗙被
+                var MaterialIDList = DayPlanPpbom.GroupBy(p => new { p.FMATERIALID, p.FStockOrgId }).Select(x => new PODemandPlanTemp { FMATERIALID = x.Key.FMATERIALID, FStockOrgId = x.Key.FStockOrgId }).ToList();
+                var _MaterialIDList = MaterialIDList.Where(p => p.FMATERIALID == "163165").ToList();
+                //LogHelper.Info("[鎻愭枡璁″垝鍑嗗闃舵]鎬荤墿鏂欒鏁�" + MaterialIDList.Count);
+                //鎻愭枡璁″垝鏁版嵁闆嗕复鏃跺瓨鍌ㄩ泦鍚�
+                List<PODemandPlanTemp> PODemandPlanTemp = new List<PODemandPlanTemp>();
+                //sql闆嗗悎 鏇存柊閲囪喘璁㈠崟鍗犵敤鐨勬彁鏂欒鍒掓暟閲�
+                List<string> sqlList = new List<string>();
+                //MaterialIDList = new List<string> { "105773" };
+                foreach (var item in MaterialIDList)
+                {
+                    //褰撳墠鐗╂枡娌℃湁閲囪喘璁㈠崟鏃� 鐩存帴璺冲嚭
+                    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)
+                    {
+                        LogHelper.Info("[鎻愭枡璁″垝寮�濮媇褰撳墠鐗╂枡鏃犻噰璐俊鎭細" + item.FMATERIALID + " 搴撳瓨缁勭粐锛�" + item.FStockOrgId);
+                        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;//鎻愬墠鏈�
+                    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)
+                        {
+                            //LogHelper.Info("[鎻愭枡璁″垝寮�濮媇褰撳墠鐗╂枡鏄庣粏鏃犻噰璐俊鎭細" + item.FMATERIALID + " 搴撳瓨缁勭粐锛�" + item.FStockOrgId);
+                            break;
+                        }
+
+                        if (NeedQty == 0)
+                            DATE = Convert.ToDateTime(_item.FHMASTERDATE).AddDays(-FFIXLEADTIME);
+                        FEntryIdList.Add(_item.FENTRYID);
+                        NeedQty += _item.NeedQty;
+
+                        //LogHelper.Info("璁板綍鏄庣粏id锛�" + _item.FENTRYID + "");
+                        //LogHelper.Info("鎬婚渶姹傞噺锛�" + NeedQty + "");
+                        //LogHelper.Info("鏈�灏忚捣璁㈤噺锛�" + FMINPOQTY + "");
+                        if (NeedQty <= FMINPOQTY)
+                        {
+                            LogHelper.Info("[鎻愭枡璁″垝]褰撳墠鐗╂枡鏄庣粏鏃犻噰璐俊鎭細" + item.FMATERIALID + ",鏁伴噺锛�" + NeedQty + "锛屾渶灏忚捣璁㈤噺锛�" + FMINPOQTY + "");
+                        }
+
+                        if ((FJITmaterialGroup == "鎬婚噺鎺у埗瑙勬牸绫�" || FJITmaterialGroup == "璁㈠崟涓撶敤涓�х被") && FEntryIdList.Count < Convert.ToInt32(FJITMaterielDemand) && i < _DayPlanPpbom.Count) //璁㈠崟涓撶敤涓�х被
+                            continue;
+
+                        //if (NeedQty >= FMINPOQTY)
+                        //{
+                        foreach (var Purchase in _PurchaseInventory)
+                        {
+                            //LogHelper.Info("閲囪喘璁㈠崟鍙锋祴璇曪細" + Purchase.FBillNo);
+                            //LogHelper.Info("鐗╂枡锛�" + Purchase.FMATERIALID + ",閲囪喘璁㈠崟鏁伴噺锛�" + Purchase.FQTY);
+                            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 Demo.Model.Model.PODemandPlan.PODemandPlanTemp
+                                    {
+                                        FID = DayPlanPpbomls.FID,
+                                        FHMASTERDATE = DATE,
+                                        FQty = DayPlanPpbomls.NeedQty,
+                                        FBILLNO = DayPlanPpbomls.FBILLNO,
+                                        FENTRYID = DayPlanPpbomls.FENTRYID,
+                                        FMATERIALID = DayPlanPpbomls.FMATERIALID,
+                                        FNumber = DayPlanPpbomls.FNumber,
+                                        OLDDATE = DayPlanPpbomls.FHMASTERDATE,
+                                        FFIXLEADTIME = FFIXLEADTIME,
+                                        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
+                                    });
+                                    //鎵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 == 0)
+                                    //    LogHelper.Info("璁㈠崟鏁伴噺涓�0");
+                                    if (Qty > _NeedQty)
+                                        Qty = _NeedQty; //璁㈠崟鏁伴噺>閲囪喘璁㈠崟鏁伴噺 鍙栭噰璐鍗�
+
+                                    //if (_NeedQty == 0)
+                                    //    LogHelper.Info("璁㈠崟鏁伴噺涓�0");
+
+                                    _NeedQty = _NeedQty - Qty;
+                                    PODemandPlanTemp.Add(new Demo.Model.Model.PODemandPlan.PODemandPlanTemp
+                                    {
+                                        FID = DayPlanPpbomls.FID,
+                                        FHMASTERDATE = DATE,
+                                        FQty = Qty,
+                                        FBILLNO = DayPlanPpbomls.FBILLNO,
+                                        FENTRYID = DayPlanPpbomls.FENTRYID,
+                                        FMATERIALID = DayPlanPpbomls.FMATERIALID,
+                                        FNumber = DayPlanPpbomls.FNumber,
+                                        OLDDATE = DayPlanPpbomls.FHMASTERDATE,
+                                        FFIXLEADTIME = FFIXLEADTIME,
+                                        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
+                                    });
+                                    //鏇存柊璁″垝鏁伴噺锛堝墿浣欓渶瑕佹帓鐨勶級 缁х画鍘昏绠椾笅涓�涓噰璐鍗�
+                                    DayPlanPpbomls.NeedQty -= Qty;
+                                    //鏇存柊閲囪喘璁㈠崟
+                                    sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount = isnull(FPODemandPlanCount,0)+ '{Qty}' where FENTRYID = {Purchase.FENTRYID}");
+                                    //鏇存柊Model
+                                    var ls = PurchaseInventory.Where(c => c.FENTRYID == Purchase.FENTRYID).FirstOrDefault();
+                                    ls.FQTY -= Qty;
+                                    if (_NeedQty <= 0)
+                                    {
+                                        foreach (var mm in mmm)
+                                        {
+                                            FEntryIdList.Remove(mm);
+                                        }
+                                        break;
+                                    }
+                                    mmm.Add(id);
+                                }
+                                //foreach (var mm in mmm)
+                                //{
+                                //    FEntryIdList.Remove(mm);
+                                //}
+                            }
+                        }
+                        NeedQty = 0;
+                        //}
+                        #region 鍓╀笅涓嶈冻鏃舵寜鏈�灏忛噰璐壒娆$敓鎴�
+                        //鍓╀笅涓嶈冻鏃舵寜鏈�灏忛噰璐壒娆$敓鎴�
+                        //else if (i == _DayPlanPpbom.Count && NeedQty > 0)
+                        //{
+                        //    NeedQty = FMINPOQTY;
+                        //    List<PurchaseInventory> _PurchaseInventory = PurchaseInventory.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId && x.FQTY > 0).ToList();
+                        //    if (_PurchaseInventory.Count == 0)
+                        //    {
+                        //        NeedQty = 0;
+                        //        break;
+                        //    }
+                        //    foreach (var Purchase in _PurchaseInventory)
+                        //    {
+                        //        if (Purchase.FQTY >= NeedQty)
+                        //        {
+                        //            List<int> mmm = new List<int>();
+                        //            foreach (int id in FEntryIdList)
+                        //            {
+                        //                mmm.Add(id);
+                        //                var DayPlanPpbomls = DayPlanPpbom.Where(c => c.FENTRYID == id && c.FMATERIALID == _item.FMATERIALID).FirstOrDefault();
+                        //                PODemandPlanTemp.Add(new Demo.Model.Model.PODemandPlan.PODemandPlanTemp
+                        //                {
+                        //                    FID = DayPlanPpbomls.FID,
+                        //                    FHMASTERDATE = DATE,
+                        //                    FQty = DayPlanPpbomls.NeedQty,
+                        //                    FBILLNO = DayPlanPpbomls.FBILLNO,
+                        //                    FENTRYID = DayPlanPpbomls.FENTRYID,
+                        //                    FMATERIALID = DayPlanPpbomls.FMATERIALID,
+                        //                    FNumber = DayPlanPpbomls.FNumber,
+                        //                    OLDDATE = DayPlanPpbomls.FHMASTERDATE,
+                        //                    FFIXLEADTIME = FFIXLEADTIME,
+                        //                    PurchseFID = Purchase.FID,
+                        //                    PurchseFentryID = Purchase.FENTRYID,
+                        //                    FSUPPLIERID = Purchase.FSUPPLIERID,
+                        //                    PurchseFNUMBER = Purchase.FNUMBER,
+                        //                    PurchseFBillNo = Purchase.FBillNo,
+                        //                    PurchseFqty = Purchase.FQTY
+                        //                });
+                        //                //鎵i櫎鏃ヨ鍒掓槑缁嗗凡琚垎閰嶇殑鏁伴噺
+                        //                DayPlanPpbomls.NeedQty = 0;
+                        //            }
+                        //            FEntryIdList.Clear();
+                        //            //鏇存柊閲囪喘璁㈠崟
+                        //            sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount  =isnull(FPODemandPlanCount,0)+  '{NeedQty}' where FENTRYID = {Purchase.FENTRYID}");
+                        //            //鎵i櫎褰撳墠琛屽搴旈噰璐鍗曟暟閲�
+                        //            var ls = PurchaseInventory.Where(c => c.FENTRYID == Purchase.FENTRYID).FirstOrDefault();
+                        //            ls.FQTY -= NeedQty;
+                        //            break;
+                        //        }
+                        //        else
+                        //        {
+                        //            NeedQty = NeedQty - Purchase.FQTY;
+                        //            decimal _NeedQty = Purchase.FQTY;//閲囪喘璁㈠崟鏁伴噺
+                        //            List<int> mmm = new List<int>();
+                        //            foreach (int id in FEntryIdList)
+                        //            {
+                        //                var DayPlanPpbomls = DayPlanPpbom.Where(c => c.FENTRYID == id && c.FMATERIALID == _item.FMATERIALID).FirstOrDefault();
+                        //                decimal Qty = DayPlanPpbomls.NeedQty;
+                        //                if (Qty > _NeedQty)
+                        //                    Qty = _NeedQty;
+                        //                _NeedQty = _NeedQty - DayPlanPpbomls.NeedQty;
+                        //                PODemandPlanTemp.Add(new Demo.Model.Model.PODemandPlan.PODemandPlanTemp
+                        //                {
+                        //                    FID = DayPlanPpbomls.FID,
+                        //                    FHMASTERDATE = DATE,
+                        //                    FQty = Qty,
+                        //                    FBILLNO = DayPlanPpbomls.FBILLNO,
+                        //                    FENTRYID = DayPlanPpbomls.FENTRYID,
+                        //                    FMATERIALID = DayPlanPpbomls.FMATERIALID,
+                        //                    FNumber = DayPlanPpbomls.FNumber,
+                        //                    OLDDATE = DayPlanPpbomls.FHMASTERDATE,
+                        //                    FFIXLEADTIME = FFIXLEADTIME,
+                        //                    PurchseFID = Purchase.FID,
+                        //                    PurchseFentryID = Purchase.FENTRYID,
+                        //                    FSUPPLIERID = Purchase.FSUPPLIERID,
+                        //                    PurchseFNUMBER = Purchase.FNUMBER,
+                        //                    PurchseFBillNo = Purchase.FBillNo,
+                        //                    PurchseFqty = Purchase.FQTY
+                        //                });
+                        //                DayPlanPpbomls.NeedQty -= Qty;
+                        //                //鏇存柊閲囪喘璁㈠崟
+                        //                sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount = isnull(FPODemandPlanCount,0)+ '{Qty}' where FENTRYID = {Purchase.FENTRYID}");
+                        //                //鏇存柊Model
+                        //                var ls = PurchaseInventory.Where(c => c.FENTRYID == Purchase.FENTRYID).FirstOrDefault();
+                        //                ls.FQTY -= Qty;
+                        //                if (_NeedQty < 0)
+                        //                {
+                        //                    foreach (var mm in mmm)
+                        //                    {
+                        //                        FEntryIdList.Remove(mm);
+                        //                    }
+                        //                    break;
+                        //                }
+                        //                mmm.Add(id);
+                        //            }
+                        //            foreach (var mm in mmm)
+                        //            {
+                        //                FEntryIdList.Remove(mm);
+                        //            }
+                        //        }
+                        //    }
+                        //    NeedQty = 0;
+                        //}
+                        #endregion
+
+                    }
+                }
+                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}锛岃�楁椂锛�" + sw.Elapsed);
+                int tlmmm = 1;
+                JArray FinalyResult = new JArray();
+                foreach (var item in PODemandPlanList)
+                {
+                    DateTime date = item.FHMASTERDATE;
+                    string PurchseFNUMBER = item.PurchseFNUMBER;
+                    JObject model = new JObject();
+                    model.Add("FHDate", date);
+                    model.Add("FSettleCurrId", new JObject() { ["Fnumber"] = "PRE001" });
+                    model.Add("FSupplierID", new JObject() { ["Fnumber"] = PurchseFNUMBER });
+
+                    JArray Fentity = new JArray();
+                    List<PODemandPlanTemp> _PODemandPlanList = PODemandPlanTemp.Where(x => x.FHMASTERDATE == date && x.PurchseFNUMBER == PurchseFNUMBER).ToList();
+                    int FSEQ = 1;
+                    foreach (var _item in _PODemandPlanList)
+                    {
+                        JObject FentityModel = new JObject();
+                        FentityModel.Add("FHPURCHASEORGID", new JObject() { ["Fnumber"] = _item.FORGNumber });//閲囪喘缁勭粐
+                        FentityModel.Add("FHMaterID", new JObject() { ["Fnumber"] = _item.FNumber });//鐗╂枡
+                        FentityModel.Add("FHQty", _item.FQty);//鏁伴噺
+                        FentityModel.Add("FHSourceInterID", _item.FID);//鏃ヨ鍒掑伐鍗旻ID
+                        FentityModel.Add("FHSourceEntryID", _item.FENTRYID);//鏃ヨ鍒掑伐鍗旻ENTRYID
+                        FentityModel.Add("FHSourceBillNo", _item.FBILLNO);//鏃ヨ鍒掑伐鍗曞崟鍙�
+                        FentityModel.Add("FHSourceBillType", "");//鏃ヨ鍒掑伐鍗曠被鍨�
+                        FentityModel.Add("FDayPlanDate", _item.OLDDATE);//鏃ヨ鍒掑伐鍗曠被鍨�
+                        FentityModel.Add("FHRelationQty", _item.PurchseFqty);//鍏宠仈鏁伴噺
+                        FentityModel.Add("FFIXLEADTIME", _item.FFIXLEADTIME);//鎻愬墠鏈�
+                        FentityModel.Add("FPURCHASEORGID", new JObject() { ["Fnumber"] = _item.FORGNumber });//閲囪喘缁勭粐
+                        FentityModel.Add("FHPOOrderInterID", _item.PurchseFID);// 閲囪喘璁㈠崟鍐呯爜锛欶HPOOrderInterID
+                        FentityModel.Add("FHPOOrderEntryID", _item.PurchseFentryID); //閲囪喘璁㈠崟瀛愬唴鐮侊細FHPOOrderEntryID
+                        FentityModel.Add("FHPOOrderBillNo", _item.PurchseFBillNo); //閲囪喘璁㈠崟鍙凤細FHPOOrderBillNo
+                        FentityModel.Add("FERPCLSID", _item.FErpClsID); //鍙戞枡鏂瑰紡
+                        //FentityModel.Add("FSEQ", FSEQ); //鍙戞枡鏂瑰紡
+                        FentityModel.Add("FUnitID", new JObject() { ["Fnumber"] = "Pcs" }); //鍙戞枡鏂瑰紡
+
+                        Fentity.Add(FentityModel);
+                        FSEQ++;
+                    }
+                    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++;
+                }
+                //sw.Stop();//缁撴潫璁℃椂
+                //LogHelper.Info("鎻愭枡璁″垝鎵ц瀹屾垚锛岃繍琛屾�绘椂闀匡細" + sw.Elapsed);
+                DBServiceHelper.ExecuteBatch(Context, sqlList);
+            }
+            catch (Exception ex)
+            {
+                LogHelper.Info("鎻愭枡璁″垝璺冲嚭锛�" + ex.Message.ToString());
+            }
+            // var PODemandPlanList22 = PODemandPlanTemp.GroupBy(p => new   {p.FSUPPLIERID,     p.FHMASTERDATE }).ToList();
+        }
+    }
+}
diff --git a/src/Model/Demo.Model/Model/DayPlanMaterial.cs b/src/Model/Demo.Model/Model/DayPlanMaterial.cs
index ec8d9ef..4b5e4a6 100644
--- a/src/Model/Demo.Model/Model/DayPlanMaterial.cs
+++ b/src/Model/Demo.Model/Model/DayPlanMaterial.cs
@@ -66,6 +66,10 @@
         /// 鐢熶骇璁㈠崟鍐呯爜
         /// </summary>
         public string FMOID { get; set; }
+        /// <summary>
+        /// 鐢熶骇璁㈠崟琛屽彿
+        /// </summary>
+        public string FMoSeq { get; set; }
 
         /// <summary>
         /// 鐢熶骇鐢ㄦ枡娓呭崟缂栧彿

--
Gitblit v1.9.1