Csharp/C#教程:LINQ和group by数据嵌套在一个结构中分享


LINQ和group by数据嵌套在一个结构中

我的结构大致如下:

List -> ID Name ... List -> ID Name ... List -> ID Name ReportCount 

监视列表可以存在于多个LoB下,但ReportCount仅用于该监视列表的该LoB下存在的报告的计数。 我在结构中需要它们,因为对于给定的监视列表,LoB中存在多少报告的计数在其他地方很重要。

我需要做的是获取不同的WatchLists列表(根据ID分组),并使ReportCount成为所有LoB中该监视列表的ReportCount的SUM。 我无法让嵌套的选择逻辑正常工作。

展平分层结构的技术是使用SelectMany方法。 你需要这样的东西:

 var result = mainList.SelectMany(x => x.LineOfBusinessList) .SelectMany(lob => lob.Watchlists) .GroupBy(wl => wl.ID) .Select(g => new { WatchlistID = g.Key, WatchlistName = g.First().Name, ReportCount = g.Sum(item => item.ReportCount) }); 

第一个SelectMany调用将原始列表转换为所有项目中所有LineOfBusiness对象的序列。 第二个SelectMany调用将一系列LineOfBusiness对象转换为包含它们的所有Watchlist对象的序列。 然后,按照ID这些Watchlist分组,并对它们执行实际查询。

上述就是C#学习教程:LINQ和group by数据嵌套在一个结构中分享的全部内容,如果对大家有所用处且需要了解更多关于C#学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/cdevelopment/1016756.html

(0)
上一篇 2021年12月31日
下一篇 2021年12月31日

精彩推荐