From e6c52d6d7b674edad782b5579148765cd89b88c4 Mon Sep 17 00:00:00 2001
From: yangle <admin@YINMOU>
Date: 星期一, 10 七月 2023 13:15:35 +0800
Subject: [PATCH] 日计划导入销售订单号

---
 WebAPI/Controllers/SCGL/日计划管理/JIT_DayPlanPlatFormBillController.cs |   78 ++++++++++++++++++++++++++++++++------
 1 files changed, 65 insertions(+), 13 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 70089ce..bce88e6 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"
@@ -776,8 +776,11 @@
                 //鍙栧簲鍙戞暟閲� FMustQty 涓嶈鍙栧�奸渶姹傛暟閲廎NeedQty 棰嗘枡鏁版嵁
                 string LLsql = string.Format(@"exec h_p_jit_PPBOMList '{0}'", fDayPlanFids);
                 List<DayPlanPickedModel> DayPlanPickedModel = new List<DayPlanPickedModel>();
+                LogService.Write("LLsql:" + LLsql);
                 ds = oCN.RunProcReturn(LLsql, "SC_WORKBILLSORTBILLMAIN");
+                LogService.Write(JsonConvert.SerializeObject(ds));
                 DayPlanPickedModel = ds.ToModelList<DayPlanPickedModel>();
+                LogService.Write(JsonConvert.SerializeObject(DayPlanPickedModel));
                 //CompleteAnalysisTempModel 鐢ㄤ簬瀛樺偍涓存椂闇�瑕佹彃鍏ユ暟鎹�
                 List<CompleteAnalysisTempModel> completeAnalysisTempModel = new List<CompleteAnalysisTempModel>();
                 //鍒涘缓瀛楀吀 鐢ㄤ簬鍌ㄥ瓨鐗╂枡 + 鍗犵敤鏁伴噺
@@ -786,8 +789,11 @@
                 LogService.Write($"榻愬鍒嗘瀽锛屾暟鎹噯澶囬樁娈碉紝鐢ㄦ椂" + sw.Elapsed + "鎬婚渶瑕佸惊鐜殑bom鏁伴噺锛�" + DatePlanList.Count);
 
                 //绗竴涓惊鐜� 鏃ヨ鍒掑伐鍗曟槑缁� 涓�澶�+涓�涓伐鍗� 涓�涓惊鐜�
+                int o = 0;
                 foreach (var item in DatePlanList)
                 {
+                    o++;
+                    LogService.Write("寰幆:" + o);
                     //鏃ヨ鍒掔敤鏂欐竻鍗曟槑缁� 姣忎竴澶╃殑瀹為檯鐢ㄦ枡鎯呭喌
                     var _BomList = BomList.Where(x => x.HMasterDate == item.HMasterDate && x.HICMOEntryID_Sec == item.HICMOEntryID_Sec).ToList();
                     //姣忎竴涓墿鏂欒繘琛屽簱瀛樿绠�
@@ -823,8 +829,9 @@
                         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)
                         {
                             //棰嗘枡鏁伴噺婊¤冻浜嗗綋鍓嶈繖涓渶姹傞噺 鐩存帴榻愬 涓嶉渶瑕佸幓鍗犵敤浠撳簱
@@ -855,19 +862,24 @@
                             });
                             //鎵i櫎鍓╀綑鍙敤棰嗘枡鏁伴噺
                             _DayPlanPickedModel.FRemainPickedQty -= need;
+                            LogService.Write($"h" + need);
                             //寰幆涓嬩竴涓墿鏂�
                             continue;
                         }
                         else
                         {
+                            LogService.Write($"kxs" + need);
                             need -= _DayPlanPickedModel.FRemainPickedQty; //鍓╀綑闇�姹傛暟閲�
+                            LogService.Write($"i1" + need);
                             FOccupyPickedCount = _DayPlanPickedModel.FRemainPickedQty;
                             _DayPlanPickedModel.FRemainPickedQty = 0;
+                            LogService.Write($"i" + need);
                         }
                         if (_pRD_WorkHouseCompar.Count > 0)
                         {
                             //缂烘枡鏁伴噺 闇�姹傛暟閲� - 瀹為檯搴撳瓨  >0 ? 涓�涓墿鏂欎笉绠″崰鐢ㄥ灏戞潯 搴撳瓨+璐т富 鏁版嵁 缂烘枡鏁伴噺鏄悓涓�涓暟閲�
                             decimal _fLackCount = need > jskcQty ? (need - jskcQty) : 0;
+                            LogService.Write($"j" + _fLackCount);
                             //LogHelper.Info("缁勭粐锛�" + _item.FStockOrgId + " ,鍙婃椂搴撳瓨" + jskcQty);
                             //鎬诲簱瀛樹负0浜� 鐩存帴缁欏嚭 缂烘枡鏁伴噺
                             if (jskcQty == 0)
@@ -900,6 +912,8 @@
                                 //缁堟璇ョ墿鏂欒绠� 杩涘叆涓嬩竴涓�
                                 continue;
                             }
+
+                            LogService.Write($"k" + 2);
                             foreach (var WorkHouse in _pRD_WorkHouseCompar)
                             {
                                 //搴撳瓨鏁版嵁鍖归厤
@@ -1574,7 +1588,9 @@
                 List<PODemandPlanTemp> PODemandPlanTemp = new List<PODemandPlanTemp>();
                 //sql闆嗗悎 鏇存柊閲囪喘璁㈠崟鍗犵敤鐨勬彁鏂欒鍒掓暟閲�
                 List<string> sqlList = new List<string>();
-                string Error = "杩愮畻澶辫触!";
+
+                LogService.Write("1");
+                string Error = "";
                 foreach (var item in MaterialIDList)
                 {
                     //褰撳墠鐗╂枡娌℃湁閲囪喘璁㈠崟鏃� 鐩存帴璺冲嚭
@@ -1584,6 +1600,9 @@
                         Error+="[鎻愭枡璁″垝寮�濮媇褰撳墠鐗╂枡鏃犻噰璐俊鎭細" + item.FNumber + " 搴撳瓨缁勭粐锛�" + item.FStockOrgName + "      ";
                         continue;
                     }
+
+                    LogService.Write("1.1");
+
                     ////LogHelper.Info(item.FMATERIALID.ToString());
                     //褰撳墠鐗╂枡鍜屽簱瀛樼粍缁囧搴旂殑闇�杩涜鎻愭枡璁″垝鐨勬暟鎹�    
                     List<DayPlanPpbom> _DayPlanPpbom = DayPlanPpbom.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId).ToList();
@@ -1597,6 +1616,9 @@
                     DateTime DATE = _DayPlanPpbom.FirstOrDefault().FHMASTERDATE;//绗竴涓璐ц捣濮嬫棩鏈�
                     int i = 0;
                     //璁板綍鍦ㄦ渶灏忛噰璐噺闇�姹備笅鐨勬棩璁″垝鏄庣粏FentyrID
+
+                    LogService.Write("1.2");
+
                     List<int> FEntryIdList = new List<int>();
                     foreach (var _item in _DayPlanPpbom)
                     {
@@ -1607,13 +1629,25 @@
                             break;
                         }
 
+                        LogService.Write("1.2.1");
+
                         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) //璁㈠崟涓撶敤涓�х被
+                        //LogService.Write(FJITmaterialGroup);
+                        //LogService.Write(FEntryIdList.Count);
+                        //LogService.Write(Convert.ToDouble(FJITMaterielDemand));
+                        //LogService.Write(_DayPlanPpbom.Count);
+                        //LogService.Write(i);
+                        if ((FJITmaterialGroup == "鎬婚噺鎺у埗瑙勬牸绫�" || FJITmaterialGroup == "璁㈠崟涓撶敤涓�х被") && FEntryIdList.Count < Convert.ToDouble(FJITMaterielDemand) && i < _DayPlanPpbom.Count) //璁㈠崟涓撶敤涓�х被
+                        {
                             continue;
+                        }
+
+                        LogService.Write("1.2.2");
 
                         foreach (var Purchase in _PurchaseInventory)
                         {
@@ -1657,6 +1691,9 @@
                                     //鎵i櫎鏃ヨ鍒掓槑缁嗗凡琚垎閰嶇殑鏁伴噺
                                     DayPlanPpbomls.NeedQty = 0;
                                 }
+
+                                LogService.Write("1.2.3");
+
                                 FEntryIdList.Clear();
                                 //鏇存柊閲囪喘璁㈠崟
                                 //sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount  =isnull(FPODemandPlanCount,0)+  '{NeedQty}' where FENTRYID = {Purchase.FENTRYID}");
@@ -1733,17 +1770,22 @@
                                 }
                             }
                         }
+
+                        LogService.Write("1.2.4");
+
                         NeedQty = 0;
 
                     }
                 }
+
                 //var PODemandPlanList222 = PODemandPlanTemp.GroupBy(p => new PODemandPlanTemp { PurchseFNUMBER = p.PurchseFNUMBER, FHMASTERDATE = p.FHMASTERDATE }).Select(x => new PODemandPlanTemp { PurchseFNUMBER = x.Key.PurchseFNUMBER, FHMASTERDATE = x.Key.FHMASTERDATE }).ToList();
                 var PODemandPlanList = PODemandPlanTemp.GroupBy(p => new { p.PurchseFNUMBER, p.FHMASTERDATE }).Select(x => new PODemandPlanTemp { PurchseFNUMBER = x.Key.PurchseFNUMBER, FHMASTERDATE = x.Key.FHMASTERDATE }).ToList();
                 //LogHelper.Info($"鎻愭枡璁″垝锛屾暟鎹噯澶囧畬鎴愶紝淇濆瓨鍒癕odel瀹炰綋锛屾�昏鏁帮細{PODemandPlanTemp.Count}");
                 int tlmmm = 0;
                 JArray FinalyResult = new JArray();
 
-             
+                LogService.Write("2");
+
                 foreach (var item in PODemandPlanList)
                 {
                     tlmmm++;
@@ -1915,12 +1957,22 @@
                     //    tlmmm++;
                 }
 
-                if (tlmmm == PODemandPlanList.Count && tlmmm != 0)
+                LogService.Write("3");
+                if (Error != "")
+                {
+                    oCN.Commit();
+                    objJsonResult.code = "0";
+                    objJsonResult.count = 0;
+                    objJsonResult.Message = "杩愮畻鎴愬姛!" + Error;
+                    objJsonResult.data = null;
+                    return objJsonResult;
+                }
+                else if (tlmmm == PODemandPlanList.Count && tlmmm != 0)
                 {
                     oCN.Commit();
                     objJsonResult.code = "1";
                     objJsonResult.count = 1;
-                    objJsonResult.Message = "杩愮畻鎴愬姛!";
+                    objJsonResult.Message = "杩愮畻鎴愬姛!" + Error;
                     objJsonResult.data = null;
                     return objJsonResult;
                 }
@@ -1929,7 +1981,7 @@
                     oCN.RollBack();//浜嬪姟鍥炴粴
                     objJsonResult.code = "0";
                     objJsonResult.count = 0;
-                    objJsonResult.Message = Error;
+                    objJsonResult.Message = "杩愮畻澶辫触!" + Error;
                     objJsonResult.data = null;
                     return objJsonResult;
                 }
@@ -1938,11 +1990,11 @@
                 //////LogHelper.Info("鎻愭枡璁″垝鎵ц瀹屾垚锛岃繍琛屾�绘椂闀匡細" + sw.Elapsed);
                 //DBServiceHelper.ExecuteBatch(Context, sqlList);
 
-                objJsonResult.code = "1";
-                objJsonResult.count = 1;
-                objJsonResult.Message = "鎻愭枡杩愮畻鎴愬姛锛�";
-                objJsonResult.data = null;
-                return objJsonResult;
+                //objJsonResult.code = "1";
+                //objJsonResult.count = 1;
+                //objJsonResult.Message = "鎻愭枡杩愮畻鎴愬姛锛�";
+                //objJsonResult.data = null;
+                //return objJsonResult;
             }
             catch (Exception e)
             {

--
Gitblit v1.9.1