动态LINQ分组语句

4

我有多个linq查询,它们检索相同的数据,只是在不同的分组级别上。 (可能有3个不同的级别)。linq查询目前的结果是自定义对象的可枚举列表。我不理解或者想知道是否有可能(减少冗余代码):

我能否使以下group by子句是动态的? 如果可以,当以该级别分组时,它能否动态地填充我的自定义对象组数据。

例如:

 var myReport_GroupProductLevel =
                from r in mySum_GroupProductLevel
                join pc in _myPlotCount on r.Strata equals pc.Strata
                join acr in _myStrataAcres on pc.Strata equals acr.Strata
                group new { r, pc, acr } by new { r.Strata, pc.Count, acr.Acres, r.GroupName, r.ProductName } into g
                select new DataSummary
                {
                    Strata = g.Key.Strata,
                    PlotCount = g.Key.Count,
                    Acres = g.Key.Acres,
                    ClassName = string.Empty,
                    GroupName = g.Key.GroupName,
                    ProductName = g.Key.ProductName,
                    TPAMEAN = g.Sum(x => x.r.TPA / x.pc.Count),
                    TPADEV = g.Select(x => x.r.TPA).StdDev(g.Key.Count)
                };

如果我只想按"GroupName"进行分组,那么我需要重新编写查询语句。我发现存在的问题是,如果我按值进行分组,那么我需要在查询中使用该值(g.Key.GroupName);但由于我正在创建一个新的自定义对象,其他未分组的值(例如"ClassName")需要一个值(我在上面使用了string.Empty,但那是静态的)。
感谢任何见解...
1个回答

8
如果有人好奇,我通过使用条件语句使其工作...因为空组合会使其折叠。
var mySum_ClassGroupProductLevel =
                from s in ReportData.myStands
                join p in ReportData.myPlots on s.ID equals p.StandID
                join t in ReportData.myTrees on p.ID equals t.PlotID
                group t by new { s.Strata, p.ID, 
                    ClassName = useClassName ? t.ClassName : string.Empty, 
                    GroupName = useGroupName ? t.GroupName : string.Empty, 
                    ProductName = useProductName ? t.ProductName : string.Empty }
                    into g
                select new
                {}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接