From a0677de5d70cdd3e0deb7fca02819495b5d6622c Mon Sep 17 00:00:00 2001 From: czw <selecti@yeah.net> Date: 星期二, 17 六月 2025 11:08:22 +0800 Subject: [PATCH] mnnnn --- HH.WCS.QingXiNongfu/core/Monitor.cs | 85 +++++++++++++++++++++++------------------- 1 files changed, 47 insertions(+), 38 deletions(-) diff --git a/HH.WCS.QingXiNongfu/core/Monitor.cs b/HH.WCS.QingXiNongfu/core/Monitor.cs index 3d777d5..8e4c336 100644 --- a/HH.WCS.QingXiNongfu/core/Monitor.cs +++ b/HH.WCS.QingXiNongfu/core/Monitor.cs @@ -1394,11 +1394,12 @@ YwlPETK_CreInwork(TKlocsFirst, "YWLTKMKQ", "鏀剁缉鑶滃弶杩�, 1); // PE鍏ュ簱 --鎻愭墸 //YwlPETKtkOrder("YWLZSXBKQ", "YWLTKMKQ", "鏀剁缉鑶滃弶杩�); //YwlPETKOutOrder("YWLTKMKQ", "YWLZSXBKQ", "鏀剁缉鑶滃弶杩�);// PE涓嚭搴�+ var tklist = LocationHelper.GetList<YWLWorkOrder>(x => x.SQL_PLineNo == "T2鎻愬崌鏈�鏀剁缉鑶� && x.WorkType == 1 && x.SQL_State == "鎵ц涓�); if (tklist.Count() > 0) { + LogHelper.Info("-鏀剁缉鑶� 閫�簱锛�); var tk = tklist.FirstOrDefault(); - var loc = LocationHelper.GetLoc(plc.location[0]); if (loc.N_CURRENT_NUM > 0 && loc.S_LOCK_STATE == "鏃�) @@ -1477,8 +1478,13 @@ else //YwlPETKOutOrder("YWLTKMKQ", "", "PE鍙夎繍");// PE灏忓嚭搴� { + LogHelper.Info("-鏀剁缉鑶� 鍑哄簱锛�); var yuworders = LocationHelper.GetList<YWLWorkOrder>(x => x.SQL_PLineNo == "T2鎻愬崌鏈�鏀剁缉鑶� && x.WorkType == 6 && x.SQL_State == "鎵ц涓�).FindAll(x => x.OutNum > 0 && DateTime.Now.Subtract(x.SQL_Modify_TIme ?? DateTime.Now).TotalSeconds > 10).OrderBy(x => !string.IsNullOrEmpty(x.TagOver) ? 1 : 2).ThenBy(x => x.TagOverTime).ToList(); - if (!yuworders.Any()) return; + if (!yuworders.Any()) + { + LogHelper.Info("-鏀剁缉鑶� 鍑哄簱锛佹病鏈夊嚭搴撳崟銆�); + return; + } var ploc = plc.location[0]; retuse: var order = yuworders.FirstOrDefault(); @@ -1510,6 +1516,7 @@ LogHelper.CErrorLog("灏忔按鍑哄簱锛� + (order.SQL_WorkNo) + "娌℃湁銆愭寚瀹氱墿鏂欙紱"); goto retuse; } + LogHelper.Info("-鏀剁缉鑶� 鍑哄簱锛� + oic + oin); string v = "YWLTKMKQ"; int ord = -1; @@ -1536,9 +1543,9 @@ var cirs = ContainerHelper.GetCntrItemRel(CNTR.FirstOrDefault().S_CNTR_CODE); if (!cirs.Any()) continue; cir = cirs.OrderByDescending(x => x.T_CREATE).FirstOrDefault(); + LogHelper.Info($"鏀剁缉鑶�鍑哄簱锛亄item.Key}鎺�[{cir.S_ITEM_CODE}-{order.SQL_ItemCode}] [{cir.S_ITEM_NAME}-{order.SQL_ItemName}] [{cir.S_CJ_NAME}-{order.S_CJ_NAME}] {(cir.S_ITEM_CODE == order.SQL_ItemCode && cir.S_ITEM_NAME == order.SQL_ItemName && cir.S_CJ_NAME == order.S_CJ_NAME)}"); if (cir.S_ITEM_CODE == order.SQL_ItemCode && cir.S_ITEM_NAME == order.SQL_ItemName && cir.S_CJ_NAME == order.S_CJ_NAME) { - //plg 2025骞�鏈�3鏃�09:08:10 Temp = new locCntItem { @@ -1570,30 +1577,32 @@ if (StartBit != null) { var tagLoc = StartBit; - if (tagLoc.N_LAYER == 1 || tagLoc.N_CURRENT_NUM == 1) - { - // 鐩存帴鍑烘彁鍗囨満浣�- //var pc = Settings.GetDeviceInfoList().Where(a => a.deviceName == "姘寸嚎鏍囩鎻愬崌鏈�).FirstOrDefault(); + // 鐩存帴鍑烘彁鍗囨満浣� - if (!string.IsNullOrEmpty(ploc) && plc != null && DeviceProcess.doorStatus[ploc]?.info == "1") + LogHelper.Info(order.SQL_PLineNo + $"-鏀剁缉鑶滃嚭搴擄紒缁堢偣{ploc}-{DeviceProcess.doorStatus[ploc]?.info}"); + if (!string.IsNullOrEmpty(ploc) && plc != null && DeviceProcess.doorStatus[ploc]?.info == "1") + { + var loc = LocationHelper.GetLoc(ploc); + LogHelper.Info(order.SQL_PLineNo + $"-鏀剁缉鑶滃嚭搴擄紒缁堢偣{loc.N_CURRENT_NUM}-{loc.S_LOCK_STATE}"); + if (loc.N_CURRENT_NUM == 0 && loc.S_LOCK_STATE == "鏃�) { - var loc = LocationHelper.GetLoc(ploc); - if (loc.N_CURRENT_NUM == 0 && loc.S_LOCK_STATE == "鏃�) + var re = TaskProcess.CreateTransport("", tagLoc.S_LOC_CODE.Trim(), loc.S_LOC_CODE, "鏀剁缉鑶滃弶杩�璐ф灦鍑烘彁鍗囨満", new List<string> { tagLoc.S_CNTR_CODE }, StartBit.N_CURRENT_NUM, 1, 1, 62); + LogHelper.CSucessLog($"from {tagLoc.S_LOC_CODE} to {loc.S_LOC_CODE} 鏀剁缉鑶滃弶杩�璐ф灦鍑烘彁鍗囨満 锛屽垱寤簕re} "); + if (re) { - var re = TaskProcess.CreateTransport("", tagLoc.S_LOC_CODE.Trim(), loc.S_LOC_CODE, "鏀剁缉鑶滃弶杩�璐ф灦鍑烘彁鍗囨満", new List<string> { tagLoc.S_CNTR_CODE }, StartBit.N_CURRENT_NUM, 1, 1, 62); - LogHelper.CSucessLog($"from {tagLoc.S_LOC_CODE} to {loc.S_LOC_CODE} 鏀剁缉鑶滃弶杩�璐ф灦鍑烘彁鍗囨満 锛屽垱寤簕re} "); - if (re) + oto.Add(oic); + if (outlock == null) { - oto.Add(oic); - if (outlock == null) - { - var r = new RowLock { S_LOCK_SRC = (StartBit.S_NOTE /*+ StartBit.HalfOrFull*/), T_LOCK_TIME = DateTime.Now, S_LOCK_STATE = "鍑哄簱閿�, S_AREA_CODE = StartBit.S_AREA_CODE, N_ROW = StartBit.N_ROW }; - db.Insertable(r).ExecuteCommand(); - } + var r = new RowLock { S_LOCK_SRC = (StartBit.S_NOTE /*+ StartBit.HalfOrFull*/), T_LOCK_TIME = DateTime.Now, S_LOCK_STATE = "鍑哄簱閿�, S_AREA_CODE = StartBit.S_AREA_CODE, N_ROW = StartBit.N_ROW }; + db.Insertable(r).ExecuteCommand(); } } } } + } + else + { + LogHelper.Info(order.SQL_PLineNo + "-鏀剁缉鑶� 鍑哄簱锛�娌℃湁鍙敤鐗╂枡"); } var set1 = new HashSet<string>(oto); @@ -2280,11 +2289,11 @@ return; //1 鍗婃墭鐩存帴涓婅揣鏋朵竴灞傘� lgrx = locsFirst.GroupBy(X => X.N_ROW).Select(x => - { - var y11 = x.OrderBy(y => y.N_COL).ToList(); - var y1 = y11.FindAll(z => z.N_CURRENT_NUM > 0).LastOrDefault(); - return y1; - }).ToList(); + { + var y11 = x.OrderBy(y => y.N_COL).ToList(); + var y1 = y11.FindAll(z => z.N_CURRENT_NUM > 0).LastOrDefault(); + return y1; + }).ToList(); foreach (var lastfull in lgrx.FindAll(x => x.HalfOrFull == 2).OrderBy(x => x.HalfOrFull).ThenBy(x => x.N_ROW)) { //var y = item.OrderBy(x => x.N_COL).ToList(); @@ -3138,22 +3147,22 @@ } else WCSHelper.Do(db => - { - //var LCRLIST = db.Queryable<LocCntrRel>().Includes(x => x.CntrItemRel).Where(x => x.S_LOC_CODE.StartsWith("QX-") && (x.CntrItemRel.S_ITEM_CODE == outOer.S_ITEM_CODE || x.CntrItemRel.S_ITEM_CODE == outOer.S_ITEM_NAME)).ToList(); - List = db.Queryable<LocCntrRel>() - .LeftJoin<CntrItemRel>((lcr, cir) => lcr.S_CNTR_CODE == cir.S_CNTR_CODE) - .LeftJoin<Location>((lcr, cir, lo) => lcr.S_LOC_CODE == lo.S_LOC_CODE) - .Where((lcr, cir) => lcr.S_LOC_CODE.StartsWith("QX-") && (cir.S_ITEM_CODE == outOer.S_ITEM_CODE || cir.S_ITEM_CODE == outOer.S_ITEM_NAME)) - .Select((lcr, cir, lo) => new Location { - S_AREA_CODE = lo.S_AREA_CODE, - S_WH_CODE = lcr.S_TYPE, - T_CREATE = lcr.T_CREATE, - N_ROW = lo.N_ROW, - N_COL = lcr.S_CNTR_CODE.StartsWith("TP") ? 0 : 1 - }).ToList(); + //var LCRLIST = db.Queryable<LocCntrRel>().Includes(x => x.CntrItemRel).Where(x => x.S_LOC_CODE.StartsWith("QX-") && (x.CntrItemRel.S_ITEM_CODE == outOer.S_ITEM_CODE || x.CntrItemRel.S_ITEM_CODE == outOer.S_ITEM_NAME)).ToList(); + List = db.Queryable<LocCntrRel>() + .LeftJoin<CntrItemRel>((lcr, cir) => lcr.S_CNTR_CODE == cir.S_CNTR_CODE) + .LeftJoin<Location>((lcr, cir, lo) => lcr.S_LOC_CODE == lo.S_LOC_CODE) + .Where((lcr, cir) => lcr.S_LOC_CODE.StartsWith("QX-") && (cir.S_ITEM_CODE == outOer.S_ITEM_CODE || cir.S_ITEM_CODE == outOer.S_ITEM_NAME)) + .Select((lcr, cir, lo) => new Location + { + S_AREA_CODE = lo.S_AREA_CODE, + S_WH_CODE = lcr.S_TYPE, + T_CREATE = lcr.T_CREATE, + N_ROW = lo.N_ROW, + N_COL = lcr.S_CNTR_CODE.StartsWith("TP") ? 0 : 1 + }).ToList(); - }); + }); if (!List.Any()) { LogHelper.Info($"澶囪揣鍗曪細{outOer.S_Work_NO} 搴撳尯涓病鏈夋壘鍒板彲鐢ㄧ墿鏂欍�"); -- Gitblit v1.9.1