`
buliedian
  • 浏览: 1248608 次
  • 性别: Icon_minigender_2
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

Linq中的SelectMany方法

阅读更多

版权声明

请尊重原创作品。转载请保持文章完整性,并以超链接形式注明原始作者“tingsking18”和主站点地址,方便其他朋友提问和指正。

先定义一些我们使用的辅助类:

说明:
类School下面有一个Class的集合,每个Class下面有有一个Student的集合。每个学生有Name和Sex两个属性。现在需要遍历School下面的所有的学生,当然我们可以用两个嵌套的foreach语句类遍历School下面的所有的Class,然后再用foreach来遍历Class下面的所有的Student,把他们添加到一个List里去。这个场景也是实际编程中经常遇到的。有了Linq我们就可以大大的简化我们的代码:

我们之需要用一下SelectMany就可以了,不用去用foreach进行两次遍历。SelectMany在MSDN中的解释:将序列的每个元素投影到 IEnumerable(T) 并将结果序列合并为一个序列。
参考MSDN:
ms-help://MS.MSDNQTR.v90.chs/fxref_system.core/html/3371348f-7811-b0bc-8c0a-2a595e08e086.htm

分享到:
评论

相关推荐

    C#/.NET - LInq中SelectMany方法

    本文将深入探讨Linq中的`SelectMany`方法,它是一种强大的查询技术,用于从序列中的每个元素中选择多个结果,并将这些结果组合成一个单一的序列。 `SelectMany`方法的核心功能在于它可以“展开”输入序列的每个元素...

    LINQ的经典例子-Where,Select、SelectMany、SkipWhile子句中使用数组索引.

    LINQ经典例子-Where、Select、SelectMany、SkipWhile子句中使用数组索引 在这个示例中,我们将学习如何使用LINQ中的Where子句来筛选数组元素,並通过使用数组索引来实现更加灵活的查询。 首先,让我们看一下Where...

    Linq 中文教程word 文档

    1. **数据查询**:Linq提供了丰富的查询操作,包括过滤(Where)、选择(Select)、投影(SelectMany)、排序(OrderBy/OrderByDescending)、分组(GroupBy)等。 2. **数据转换**:Linq可以将一种数据结构转换为另...

    LINQ中文教程LINQ中文教程

    2. **查询的投影(Projection)**:`SelectMany()`允许从单一元素投影到多个元素,常用于处理嵌套集合。 3. **匿名类型**:在查询表达式中创建的类型,没有名称,仅用于临时存储查询结果。 本教程将详细讲解这些...

    Linq 之路,通俗易懂的讲解Linq用法

    - **数据转换(Projecting)**:如`Select`、`SelectMany`等用于转换数据结构的操作。 - **连接(Joining)**:如`Join`、`GroupJoin`等用于连接多个数据集的操作。 - **排序和分组(Ordering and Grouping)**:如`Order...

    完整LINQ中文版文档

    2. **查询操作符**:LINQ提供了一系列内置的操作符,如筛选(`Where()`)、选择(`Select()`)、投影(`SelectMany()`)、分组(`GroupBy()`)、聚合(`Sum()`, `Count()`, `Average()`等)和连接(`Join()`、`Group...

    Linq实例

    Linq支持多种查询操作,包括过滤(Where)、选择(Select)、投影(SelectMany)、排序(OrderBy/OrderByDescending)、分组(GroupBy)、联接(Join/GroupJoin)等。这些操作可以通过组合使用,实现复杂的查询需求...

    linq微软官方资料CSharp

    7. **查询的组合**:通过使用`Join()`, `GroupJoin()`, `SelectMany()`等方法,可以组合多个查询,创建更复杂的查询逻辑。 这个压缩包中的"CSharpSamples"很可能包含了多种 LINQ 示例,涵盖了基本操作到高级特性的...

    C# linq操作xml

    IEnumerable<XElement> nestedElements = doc.Descendants("parent").SelectMany(p => p.Descendants("child")); ``` **更新XML:** 1. **添加新节点**:使用`Add()`或`AddFirst()`方法可以向XML树中添加新的元素...

    java里面的linq

    3. **查询操作符**:JavaLinq提供了丰富的查询操作符,包括`where()`(过滤)、`select()`(映射)、`selectMany()`(扁平化)、`groupBy()`(分组)、`orderBy()`(排序)、`skip()`(跳过)、`take()`(获取前N个...

    linq入门与提高学习心得

    11. 数据投影:通过`SelectMany()`方法,可以从一个集合的元素中选择出多个值,形成一个新的集合。 学习LINQ不仅能够提升编程效率,还能帮助理解函数式编程的概念。对于初学者来说,建议从基础的查询表达式和方法链...

    CoolCode.Linq

    2. **Linq的基本操作**:主要包括选择(Select)、投影(SelectMany)、过滤(Where)、分组(GroupBy)、排序(OrderBy/ThenBy)、连接(Join)、并集(Union)、交集(Intersect)、差集(Except)等。 3. **Linq...

    MSDN:101 LINQ Samples

    5. **LINQ - Conversion Operators**:转换操作符如Select和SelectMany用于将一个类型的序列转换为另一个类型。这些操作符在数据类型转换和映射中起着关键作用。 6. **LINQ - Set Operators**:集操作符,如Union、...

    linq查询用于寻找文件中单词和句子的实例C#窗口程序

    string[] words = File.ReadAllLines("file.txt").Select(line => line.Split(' ')).SelectMany(wordsInLine => wordsInLine).ToArray(); var query = from word in words where word.StartsWith("特定前缀") ...

    LINQ实例大全

    `Select`用于映射每个元素到新类型或新结构,而`SelectMany`则将多个集合展开为单一序列。 2. **LINQ - Miscellaneous Operators** 这类操作符包括`Where`(过滤)、`OrderBy`(排序)、`ThenBy`(次要排序)、`...

    LinQ分步骤学习教程

    - 分组聚合:`GroupBy()`不仅用于分组,还可以配合`SelectMany()`和`Sum()`等聚合函数对数据进行统计。 6. **LinQ与Ajax和JavaScript的结合** - 在本教程中,除了LinQ之外,还涉及到Ajax和JavaScript的相关资料。...

    LINQ实战原书代码

    - 多表关联:`Join`操作结合`SelectMany`进行多层嵌套。 - 自定义查询操作符:通过扩展方法创建自定义的查询逻辑。 通过对《LINQ实战》源代码的学习,开发者不仅能掌握基础的查询语法,还能了解到如何在实际项目...

    LINQ教程全集完整版

    `SelectMany`则用于将一个集合的元素转换为另一个集合。 4. **过滤和条件查询**: `Where`操作符用于基于指定条件筛选数据。 5. **聚合函数**: `Count`、`Sum`、`Average`、`Max`和`Min`等聚合函数可用于计算集合的...

    Linq中文版帮助文档(.chm文件)

    10. **查询的转换和投影**:通过`Select()`和`SelectMany()`转换数据结构,以及如何投影查询结果为新的类型。 通过这份中文版的帮助文档,无论是初学者还是经验丰富的开发者,都能深入理解和掌握Linq的精髓,提升在...

    LINQ实战(最新完整版本)

    2. **投影(SelectMany)**:用于将一个集合转换为另一个集合,常用于扁平化嵌套数据。 3. **过滤(Where)**:根据指定条件筛选数据,相当于SQL的WHERE子句。 4. **排序(OrderBy/OrderByDescending)**:对查询...

Global site tag (gtag.js) - Google Analytics