From 74a352255e4a8d7cd10eaaab8cb44f568f88b6c2 Mon Sep 17 00:00:00 2001
From: czw <selecti@yeah.net>
Date: 星期二, 17 六月 2025 16:10:59 +0800
Subject: [PATCH] 清溪问题处理

---
 HH.WCS.QingXiNongfu/core/TaskCore.cs |  243 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 243 insertions(+), 0 deletions(-)

diff --git a/HH.WCS.QingXiNongfu/core/TaskCore.cs b/HH.WCS.QingXiNongfu/core/TaskCore.cs
index 4faf73c..1d0daeb 100644
--- a/HH.WCS.QingXiNongfu/core/TaskCore.cs
+++ b/HH.WCS.QingXiNongfu/core/TaskCore.cs
@@ -250,7 +250,250 @@
             }
         }
 
+        /// <summary>
+        /// 60鍒嗛挓鏇存柊涓�搴撳
+        /// </summary>
+        /// <param name="min"></param>
+        public static void CheckKuRong(int min)
+        {
+            try
+            {
+                Console.WriteLine("CheckKurRong");
+                //濡傛灉琛ㄥ唴娌℃湁鏁版嵁灏卞垵濮嬪寲涓�笅锛屾湁鏁版嵁浜唌odify鏃堕棿鍜屽綋鍓嶆椂闂磋秴杩�0min鍐嶇粺璁′竴娆�+                var db = new SqlHelper<object>().GetInstance();
+                var info = db.Queryable<KuRong>().First();
+                if (info == null || DateTime.Now.Subtract(info.T_MODIFY).TotalMinutes > min)
+                {
+                    //1銆佹煡鍒板皬鏉垮簱鍖轰笅闈㈡墍鏈夌殑搴撲綅
+                    var totalX = 0;
+                    var totalRows = 0;
+                    var list = new List<KuRong>();
+                    var areas = db.Queryable<Location>().Select(x => x.S_AREA_CODE).ToList().FindAll(x => System.Text.RegularExpressions.Regex.IsMatch(x, @"QX-\d+_[A-Z]+")).Select(x => x.Split('_')[0]).Distinct().ToList(); //GetAreas();
+                    areas.ForEach(area =>
+                    {
+                        totalX += db.Queryable<Location>().Count(b => b.S_AREA_CODE.StartsWith(area) && b.S_AREA_CODE.Contains("_X"));
+                        totalRows += db.Queryable<Location>().Where(b => b.S_AREA_CODE.StartsWith(area) && b.S_AREA_CODE.Contains("_X")).Select(b => b.N_ROW).Distinct().Count();
+                        var aresList = db.Queryable<Location>().Where(b => b.S_AREA_CODE.StartsWith(area) && b.S_AREA_CODE.Contains("_")).Select(b => b.S_AREA_CODE).Distinct().ToList();
+                        aresList = aresList.Select(a => a.Split('_')[0]).Distinct().ToList();
+                        aresList.ForEach(a =>
+                        {
+                            //b => b.S_AREA_CODE == a + "_X"
+                            Console.WriteLine("area:" + a);
+                            // && b.S_AREA_CODE.EndsWith("X")
+                            var rows = db.Queryable<Location>().Where(b => b.S_AREA_CODE.StartsWith(a)).Select(b => b.N_ROW).Distinct().ToList();
+                            if (rows.Count > 0)
+                            {
+                                Console.WriteLine(string.Join(",", rows));
+                                rows.ForEach(b =>
+                                {
+                                    var kr = new KuRong() { StorageLoc = a.Split('-')[1] + "-" + b, T_MODIFY = DateTime.Now };
+                                    Console.WriteLine(kr.StorageLoc);
+                                    //姣忎竴鎺掕鏌ヤ竴涓嬫湁娌℃湁鎵樼洏
+                                    var listLoc = db.Queryable<Location>().Where(c => c.S_AREA_CODE.Contains(c.S_AREA_CODE) && c.N_ROW == b && c.N_CURRENT_NUM > 0).ToList();
+                                    if (!listLoc.Any())
+                                    {
+                                        //娌℃墭鐩橈紝榛樿鏈�ぇ瀹归噺鏄皬鏉跨殑鏁伴噺
+                                        var count = db.Queryable<Location>().Count(c => c.S_AREA_CODE == a + "_X" && c.N_ROW == b) * 2 * 2;//2灞�鎵�+                                        kr.MaxCapacity = count;
+                                        kr.AvailableCapacity = count;
+                                        kr.ProductItem = "";
+                                    }
+                                    else
+                                    {
+                                        //鏈夋墭鐩�鍒ゆ柇鏄彔2灞傝繕鏄�灞傦紝瑕佽幏鍙栫墿鏂欎俊鎭�+                                        var lcr = db.Queryable<LocCntrRel>().Includes(it => it.CntrItemRel).Where(l => l.S_LOC_CODE == listLoc[0].S_LOC_CODE).First();
+                                        if (lcr != null && lcr.CntrItemRel != null)
+                                        {
+                                            var maxLayer = ContainerHelper.GetItem(ass => ass.S_ITEM_NAME == lcr.CntrItemRel.S_ITEM_NAME && ass.S_ITEM_CODE == lcr.CntrItemRel.S_ITEM_CODE)?.MaxLayer ?? listLoc[0].N_CAPACITY;
+                                            var total = db.Queryable<Location>().Count(c => c.S_AREA_CODE == listLoc[0].S_AREA_CODE && c.N_ROW == b) * maxLayer * 2;
+                                            var count = db.Queryable<Location>().Where(c => c.S_AREA_CODE == listLoc[0].S_AREA_CODE && c.N_ROW == b && c.N_CURRENT_NUM > 0).Sum(c => c.N_CURRENT_NUM) * 2;  // 鎸囧畾缁熻瀛楁
 
+                                            kr.ProductItem = lcr.CntrItemRel.S_ITEM_CODE;
+                                            kr.MaxCapacity = total;
+                                            kr.FilledCapacity = count;
+                                            kr.AvailableCapacity = total - count;
+                                        }
+                                    }
+                                    list.Add(kr);
+                                });
+                            }
+                            else
+                            {
+                                Console.WriteLine("area:" + a + ":鏈幏鍙栧埌鎺�);
+                            }
+                        });
 
+                    });
+                    var ordersCount = db.Queryable<WorkOrder>().Where(a => a.SQL_State == "鎵ц涓�).Count();
+                    var totalDesiredCapacity = ordersCount * 4 * 3 * (totalX / totalRows);
+                    LogHelper.Error($"鎴愬搧灏忔澘鍖烘�璐т綅鏄瘂totalX},鎬绘帓鏁版槸{totalRows},褰撳墠鎵ц宸ュ崟鏁伴噺鏄瘂ordersCount}", null);
+                    var totalAvailableCapacity = list.Sum(a => a.AvailableCapacity);
+                    var totalAssignableCapacity = totalAvailableCapacity - totalDesiredCapacity;
+                    list.ForEach(a => { a.DesiredCapacity = totalDesiredCapacity; a.CRC = totalAvailableCapacity; a.RAC = totalAssignableCapacity; });
+                    if (info == null)
+                    {
+                        /*鈥婼QL Server鈥�1000 鏉�鎵规	鍗曚釜 INSERT 璇彞鏈�鏀寔 1000 鏉�VALUES 瀛愬彞锛岃秴鍑轰細鎶ヨ娉曢敊璇�*/
+                        db.Insertable(list).ExecuteCommand();
+                    }
+                    else
+                    {
+                        //鏇存柊
+                        list.ForEach(a =>
+                        {
+                            var old = db.Queryable<KuRong>().Where(b => b.StorageLoc == a.StorageLoc).First();
+                            if (old != null)
+                            {
+                                old.MaxCapacity = a.MaxCapacity;
+                                old.AvailableCapacity = a.AvailableCapacity;
+                                old.FilledCapacity = a.FilledCapacity;
+                                old.ProductItem = a.ProductItem;
+                                old.DesiredCapacity = a.DesiredCapacity;
+                                old.CRC = a.CRC;
+                                old.RAC = a.RAC;
+                                old.T_MODIFY = DateTime.Now;
+                                db.Updateable(old).UpdateColumns(it => new { it.MaxCapacity, it.FilledCapacity, it.AvailableCapacity, it.ProductItem, it.T_MODIFY }).ExecuteCommand();
+                            }
+                            else
+                            {
+                                db.Insertable(a).ExecuteCommand();
+                            }
+                        });
+                    }
+                }
+            }
+            catch (Exception ex)
+            {
+                Console.WriteLine(ex.Message);
+                LogHelper.Error(ex.Message, ex);
+            }
+
+            //缁熻褰撳墠浜х嚎
+        }
+
+        internal static void Kuronggg()
+        {
+            int min = 60;
+            try
+            {
+                LogHelper.Info("Run>>CheckKurRong");
+                //濡傛灉琛ㄥ唴娌℃湁鏁版嵁灏卞垵濮嬪寲涓�笅锛屾湁鏁版嵁浜唌odify鏃堕棿鍜屽綋鍓嶆椂闂磋秴杩�0min鍐嶇粺璁′竴娆�+                var db = new SqlHelper<object>().GetInstance();
+                var info = db.Queryable<KuRong>().First();
+                if (info == null || DateTime.Now.Subtract(info.T_MODIFY).TotalMinutes > min)
+                {
+                    //1銆佹煡鍒板皬鏉垮簱鍖轰笅闈㈡墍鏈夌殑搴撲綅
+                    var totalX = 0;
+                    var totalRows = 0;
+                    var list = new List<KuRong>();
+                    var areas = db.Queryable<Location>().Select(x => x.S_AREA_CODE).ToList().FindAll(x => System.Text.RegularExpressions.Regex.IsMatch(x, @"QX-\d+_[A-Z]+")).Select(x => x.Split('_')[0]).Distinct().ToList(); //GetAreas();
+                    areas.ForEach(area =>
+                    {
+                        totalX += db.Queryable<Location>().Count(b => b.S_AREA_CODE.StartsWith(area) && b.S_AREA_CODE.Contains("_X"));
+                        totalRows += db.Queryable<Location>().Where(b => b.S_AREA_CODE.StartsWith(area) && b.S_AREA_CODE.Contains("_X")).Select(b => b.N_ROW).Distinct().Count();
+                        var aresList = db.Queryable<Location>().Where(b => b.S_AREA_CODE.StartsWith(area) && b.S_AREA_CODE.Contains("_")).Select(b => b.S_AREA_CODE).Distinct().ToList();
+                        aresList = aresList.Select(a => a.Split('_')[0]).Distinct().ToList();
+                        aresList.ForEach(a =>
+                        {
+                            //b => b.S_AREA_CODE == a + "_X"
+                            Console.WriteLine("area:" + a);
+                            // && b.S_AREA_CODE.EndsWith("X")
+                            var rows = db.Queryable<Location>().Where(b => b.S_AREA_CODE.StartsWith(a)).Select(b => b.N_ROW).Distinct().ToList();
+                            if (rows.Count > 0)
+                            {
+                                Console.WriteLine(string.Join(",", rows));
+                                rows.ForEach(b =>
+                                {
+                                    var kr = new KuRong() { StorageLoc = a.Split('-')[1] + "-" + b, T_MODIFY = DateTime.Now };
+                                    Console.WriteLine(kr.StorageLoc);
+                                    //姣忎竴鎺掕鏌ヤ竴涓嬫湁娌℃湁鎵樼洏
+                                    var listLoc = db.Queryable<Location>().Where(c => c.S_AREA_CODE.Contains(c.S_AREA_CODE) && c.N_ROW == b && c.N_CURRENT_NUM > 0).ToList();
+                                    if (!listLoc.Any())
+                                    {
+                                        //娌℃墭鐩橈紝榛樿鏈�ぇ瀹归噺鏄皬鏉跨殑鏁伴噺
+                                        var count = db.Queryable<Location>().Count(c => c.S_AREA_CODE == a + "_X" && c.N_ROW == b) * 2 * 2;//2灞�鎵�+                                        kr.MaxCapacity = count;
+                                        kr.AvailableCapacity = count;
+                                        kr.ProductItem = "";
+                                    }
+                                    else
+                                    {
+                                        //鏈夋墭鐩�鍒ゆ柇鏄彔2灞傝繕鏄�灞傦紝瑕佽幏鍙栫墿鏂欎俊鎭�+                                        var lcr = db.Queryable<LocCntrRel>().Includes(it => it.CntrItemRel).Where(l => l.S_LOC_CODE == listLoc[0].S_LOC_CODE).First();
+                                        if (lcr != null && lcr.CntrItemRel != null)
+                                        {
+                                            var maxLayer = ContainerHelper.GetItem(ass => ass.S_ITEM_NAME == lcr.CntrItemRel.S_ITEM_NAME && ass.S_ITEM_CODE == lcr.CntrItemRel.S_ITEM_CODE)?.MaxLayer ?? listLoc[0].N_CAPACITY;
+                                            var total = db.Queryable<Location>().Count(c => c.S_AREA_CODE == listLoc[0].S_AREA_CODE && c.N_ROW == b) * maxLayer * 2;
+                                            var count = db.Queryable<Location>().Where(c => c.S_AREA_CODE == listLoc[0].S_AREA_CODE && c.N_ROW == b && c.N_CURRENT_NUM > 0).Sum(c => c.N_CURRENT_NUM) * 2;  // 鎸囧畾缁熻瀛楁
+
+                                            kr.ProductItem = lcr.CntrItemRel.S_ITEM_CODE;
+                                            kr.MaxCapacity = total;
+                                            kr.FilledCapacity = count;
+                                            kr.AvailableCapacity = total - count;
+                                        }
+                                    }
+                                    list.Add(kr);
+                                });
+                            }
+                            else
+                            {
+                                Console.WriteLine("area:" + a + ":鏈幏鍙栧埌鎺�);
+                            }
+                        });
+
+                    });
+
+                    var ordersCount = 0;// db.Queryable<WorkOrder>().Where(a => a.SQL_State == "鎵ц涓�).Count();
+                    foreach (var pline in Settings.GetDeviceInfoList().FindAll(x => x.deviceType == 9))
+                    {
+                        ordersCount += db.Queryable<WorkOrder>().Where(a => a.SQL_PLineNo == pline.deviceName && a.SQL_State == "鎵ц涓�).Count();
+                    }
+                    var totalDesiredCapacity = ordersCount * 4 * 3 * (totalX / totalRows);
+                    LogHelper.Error($"鎴愬搧灏忔澘鍖烘�璐т綅鏄瘂totalX},鎬绘帓鏁版槸{totalRows},褰撳墠鎵ц宸ュ崟鏁伴噺鏄瘂ordersCount}", new Exception("Kurong"));
+                    var totalAvailableCapacity = list.Sum(a => a.AvailableCapacity);
+                    var totalAssignableCapacity = totalAvailableCapacity - totalDesiredCapacity;
+                    list.ForEach(a => { a.DesiredCapacity = totalDesiredCapacity; a.CRC = totalAvailableCapacity; a.RAC = totalAssignableCapacity; });
+                    if (info == null)
+                    {
+                        /*鈥婼QL Server鈥�1000 鏉�鎵规	鍗曚釜 INSERT 璇彞鏈�鏀寔 1000 鏉�VALUES 瀛愬彞锛岃秴鍑轰細鎶ヨ娉曢敊璇�*/
+                        for (int i = 0; i < list.Count; i += 1000)
+                        {
+                            db.Insertable(list.Skip(i).Take(1000).ToList()).ExecuteCommand();
+                        }
+                    }
+                    else
+                    {
+                        //鏇存柊
+                        list.ForEach(a =>
+                        {
+                            var old = db.Queryable<KuRong>().Where(b => b.StorageLoc == a.StorageLoc).First();
+                            if (old != null)
+                            {
+                                old.MaxCapacity = a.MaxCapacity;
+                                old.AvailableCapacity = a.AvailableCapacity;
+                                old.FilledCapacity = a.FilledCapacity;
+                                old.ProductItem = a.ProductItem;
+                                old.DesiredCapacity = a.DesiredCapacity;
+                                old.CRC = a.CRC;
+                                old.RAC = a.RAC;
+                                old.T_MODIFY = DateTime.Now;
+                                db.Updateable(old).UpdateColumns(it => new { it.MaxCapacity, it.FilledCapacity, it.AvailableCapacity, it.ProductItem, it.T_MODIFY }).ExecuteCommand();
+                            }
+                            else
+                            {
+                                db.Insertable(a).ExecuteCommand();
+                            }
+                        });
+                    }
+                }
+
+                LogHelper.Info("OVER<<CheckKurRong");
+            }
+            catch (Exception ex)
+            {
+                Console.WriteLine(ex.Message);
+                LogHelper.Error(ex.Message, ex);
+            }
+
+        }
     }
 }

--
Gitblit v1.9.1