欢迎来到本篇LINQ教程,本文介绍了如何使用C#中的LINQ(Language Integrated Query)。LINQ是C#中的功能,可用于从集合中检索,过滤和操作数据。

LINQ的基本概念

使用LINQ时,我们可以将一个或多个查询操作链接在一起,以获取所需的数据。以下是LINQ查询的基本构造块:

  1. 数据源 - 您要查询的集合或数据源。
  2. 查询运算符 - 用于执行特定操作的方法,如筛选,排序和分组。
  3. 查询表达式 - 构建查询的Lambda表达式。

例如,下面的代码演示了如何使用LINQ从字符串数组中选择以“a”开头的元素:

string[] words = { "apple", "banana", "apricot", "cherry" };
var aWords = words.Where(w => w.StartsWith("a"));
foreach (var word in aWords)
{
    Console.WriteLine(word);
}
// 输出:apple apricot


在此示例中,words是数据源,Where是查询运算符,w => w.StartsWith(“a”)是查询表达式。

查询运算符

LINQ中提供了许多查询运算符,我们可以根据需要选择适当的运算符。以下是一些常见的查询运算符:

  • Where:根据条件返回集合中的元素。
  • Select:选择集合中的特定字段。
  • OrderBy / OrderByDescending:将集合按照某个字段升序或降序排列。
  • GroupBy:按照指定字段对集合进行分组,并返回每个组的元素列表。
  • Join:根据两个集合中的相同字段将元素进行匹配。

以下是一些示例使用这些运算符的代码:

// 使用Where运算符筛选集合中“a”开头的元素
var aWords = words.Where(w => w.StartsWith("a"));
// 使用Select运算符选择集合中的特定字段
var wordLengths = words.Select(w => w.Length);
// 使用OrderBy运算符按长度对单词进行排序
var sortedWords = words.OrderBy(w => w.Length);
// 使用GroupBy运算符根据单词的长度对它们进行分组
var wordGroups = words.GroupBy(w => w.Length);
// 使用Join运算符将两个集合连接起来
var combinedList = words.Join(otherWords,
                              w => w.Length,
                              ow => ow.Length,
                              (w, ow) => w + " and " + ow);


查询表达式

查询表达式是用于构建查询的Lambda表达式。以下是一些示例查询表达式:

// 查询集合中长度为5的单词
var fiveLetterWords = from word in words
                      where word.Length == 5
                      select word;
// 查询集合中长度为5的单词,并按字母排序
var sortedFiveLetterWords = from word in words
                            where word.Length == 5
                            orderby word
                            select word;
// 查询集合中所有以“a”开头的单词,并将它们连接成一个字符串
var aWords = from word in words
             where word.StartsWith("a")
             select word;
string concatenatedWords = string.Join(", ", aWords);


确定查询类型

在使用LINQ时,您可以使用以下两种查询类型之一:

  1. 迭代式查询 - 提取集合中的每个元素并执行运算符的操作。
  2. 延迟查询 - 不执行任何操作,直到需要枚举返回的结果时才进行操作。

需要注意的是C#中的LINQ查询是延迟执行的。这意味着在查询表达式被执行之前,不会对数据源进行任何计算。只有在数据源被枚举时,运算符才会应用到数据上。