欢迎来到本篇LINQ教程,本文介绍了如何使用C#中的LINQ(Language Integrated Query)。LINQ是C#中的功能,可用于从集合中检索,过滤和操作数据。
LINQ的基本概念
使用LINQ时,我们可以将一个或多个查询操作链接在一起,以获取所需的数据。以下是LINQ查询的基本构造块:
- 数据源 - 您要查询的集合或数据源。
- 查询运算符 - 用于执行特定操作的方法,如筛选,排序和分组。
- 查询表达式 - 构建查询的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时,您可以使用以下两种查询类型之一:
- 迭代式查询 - 提取集合中的每个元素并执行运算符的操作。
- 延迟查询 - 不执行任何操作,直到需要枚举返回的结果时才进行操作。
需要注意的是C#中的LINQ查询是延迟执行的。这意味着在查询表达式被执行之前,不会对数据源进行任何计算。只有在数据源被枚举时,运算符才会应用到数据上。