合规国际互联网加速 OSASE为企业客户提供高速稳定SD-WAN国际加速解决方案。 广告
# 如何:对分组操作执行子查询(C# 编程指南) 本主题演示执行以下任务的两种不同方式:创建一个查询,以便将源数据排序到不同的组中,然后分别对每个组执行子查询。每个示例中的基本技术都是使用一个名为 newGroup 的“延续”对源元素进行分组,然后生成一个针对 newGroup 的新的子查询。此子查询是针对外部查询所创建的每个新组运行的。请注意,在此特定示例中,最终的输出不是组,而是匿名类型的平面序列。 有关如何分组的更多信息,请参见[group 子句(C# 参考)](https://msdn.microsoft.com/zh-cn/library/bb384063.aspx)。 有关延续的更多信息,请参见 [into(C# 参考)](https://msdn.microsoft.com/zh-cn/library/bb311045.aspx)。下面的示例使用内存中数据结构作为数据源,但相同的原理适用于任何种类的 LINQ 数据源。 ``` public void QueryMax() { var queryGroupMax = from student in students group student by student.Year into studentGroup select new { Level = studentGroup.Key, HighestScore = (from student2 in studentGroup select student2.ExamScores.Average()).Max() }; int count = queryGroupMax.Count(); Console.WriteLine("Number of groups = {0}", count); foreach (var item in queryGroupMax) { Console.WriteLine(" {0} Highest Score={1}", item.Level, item.HighestScore); } } ``` ## 编译代码 此示例包含对[如何:查询对象集合(C# 编程指南)](https://msdn.microsoft.com/zh-cn/library/bb907066.aspx)内示例应用程序中定义的对象的引用。若要编译和运行此方法,请将它粘贴到该应用程序的 StudentClass 类中,并且在 Main 方法中添加对它的调用。 在改写此方法以适合您自己的应用程序时,请记住 LINQ 需要 .NET Framework 3.5 版,并且项目必须包含一个对 System.Core.dll 的引用和一条针对 System.Linq 的 using 指令。LINQ to SQL、LINQ to XML 和 LINQ to DataSet 类型需要其他 using 指令和引用。有关更多信息,请参见 [How to: Create a LINQ Project](https://msdn.microsoft.com/zh-cn/library/bb546156.aspx)。 ## 请参阅 [LINQ 查询表达式(C# 编程指南)](https://msdn.microsoft.com/zh-cn/library/bb397676.aspx)