From 2aef482fa7431fb47eef94081ff23ec220f89820 Mon Sep 17 00:00:00 2001 From: hutongqing <hutongqing@hnkhzn.com> Date: 星期五, 24 一月 2025 09:10:31 +0800 Subject: [PATCH] 1 --- WIDESEAWCS_Server/WIDESEAWCS_QuartzJob/Service/RouterService.cs | 55 ++++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 54 insertions(+), 1 deletions(-) diff --git a/WIDESEAWCS_Server/WIDESEAWCS_QuartzJob/Service/RouterService.cs b/WIDESEAWCS_Server/WIDESEAWCS_QuartzJob/Service/RouterService.cs index de20dd7..423ae6d 100644 --- a/WIDESEAWCS_Server/WIDESEAWCS_QuartzJob/Service/RouterService.cs +++ b/WIDESEAWCS_Server/WIDESEAWCS_QuartzJob/Service/RouterService.cs @@ -47,7 +47,7 @@ try { //鏌ヨ涓嬩竴涓矾鐢变俊鎭� - List<Dt_Router> dt_Routers = BaseDal.QueryData(x => x.NextPosi == endPosi || x.ChildPosi == endPosi, new Dictionary<string, OrderByType> { { nameof(Dt_Router.IsEnd), OrderByType.Desc } }); + List<Dt_Router> dt_Routers = BaseDal.QueryData(x => (x.NextPosi == endPosi || x.ChildPosi == endPosi), new Dictionary<string, OrderByType> { { nameof(Dt_Router.IsEnd), OrderByType.Desc } }); if (dt_Routers.Count > 0) { foreach (var item in dt_Routers) @@ -87,6 +87,59 @@ } /// <summary> + /// 鏍规嵁璧风偣/褰撳墠浣嶇疆銆佺粓鐐硅幏鍙栦笅涓�涓瓙鑺傜偣銆� + /// </summary> + /// <param name="startPosi">璧风偣/褰撳墠浣嶇疆銆�</param> + /// <param name="endPosi">缁堢偣銆�</param> + /// <param name="routeType">璺敱绫诲瀷銆�</param> + /// <returns>杩斿洖璺敱瀹炰綋闆嗗悎銆�</returns> + public List<Dt_Router> QueryNextRoutes(string startPosi, string endPosi, int routeType) + { + //todo 鏂规硶闇�浼樺寲 + List<Dt_Router> routers = new List<Dt_Router>(); + try + { + //鏌ヨ涓嬩竴涓矾鐢变俊鎭� + List<Dt_Router> dt_Routers = BaseDal.QueryData(x => (x.NextPosi == endPosi || x.ChildPosi == endPosi) && x.InOutType == routeType, new Dictionary<string, OrderByType> { { nameof(Dt_Router.IsEnd), OrderByType.Desc } }); + if (dt_Routers.Count > 0) + { + foreach (var item in dt_Routers) + { + //濡傛灉涓嬩竴涓矾鐢辩殑璧风偣鍜岀粓鐐归兘鍖归厤锛屽垯娣诲姞鍒拌矾鐢卞垪琛ㄤ腑 + if (item.StartPosi == startPosi && !routers.Any(x => x.Id == item.Id)) + { + routers.Add(item); + } + else + { + //鍚﹀垯锛岄�掑綊鏌ヨ涓嬩竴涓矾鐢辩殑璧风偣 + List<Dt_Router> tempRouters = QueryNextRoutes(startPosi, item.StartPosi, routeType); + foreach (var router in tempRouters) + { + //濡傛灉涓嬩竴涓矾鐢辩殑璧风偣鍜岀粓鐐归兘鍖归厤锛屽垯娣诲姞鍒拌矾鐢卞垪琛ㄤ腑 + if (router.StartPosi == startPosi && !routers.Any(x => x.Id == router.Id)) + { + routers.Add(router); + } + } + } + } + } + else + { + //濡傛灉鏌ヨ涓嶅埌涓嬩竴涓矾鐢变俊鎭紝鍒欐姏鍑哄紓甯� + throw new Exception($"璇ヨ矾寰勬湭閰嶇疆鎴栭厤缃敊璇�,璇锋鏌ヨ澶囪矾鐢变俊鎭�,璧风偣:銆恵startPosi}銆�,缁堢偣:銆恵endPosi}銆�"); + } + } + catch (Exception ex) + { + //throw new Exception(ex.Message); + //璁板綍閿欒淇℃伅 + } + return routers; + } + + /// <summary> /// 鏍规嵁璁惧缂栧彿鑾峰彇瀵瑰簲鐨勮矾鐢辩偣浣嶇紪鍙�(杈撻�佺嚎绔欏彴缂栧彿)淇℃伅 /// </summary> /// <param name="deviceCode">璁惧缂栧彿</param> -- Gitblit v1.9.3