LINQ是C#中用于操作集合的查询功能,需引入System.Linq命名空间;支持查询表达式语法(类似SQL)和方法语法(Lambda),如var query = from name in names where name.StartsWith("A") select name;常用操作符包括Where筛选、Select投影、OrderBy排序、Take/Skip分页、Any/All判断、FirstOrDefault获取首元素;可查询复杂对象如List<Person>,并利用延迟执行特性,在遍历时才真正运行查询,避免意外需用ToList()立即执行。

在C#中,LINQ(Language Integrated Query)是一种强大的查询功能,允许你以简洁、可读性强的方式操作数据集合。特别是 LINQ to Objects,用于对内存中的集合(如数组、List、Dictionary等)进行查询。下面介绍基本的LINQ查询语法和常用操作。
using System.Linq;
示例数据:
List<string> names = new List<string> { "Alice", "Bob", "Charlie", "Anna", "David" };查询表达式语法(推荐初学者):
var query = from name in names
where name.StartsWith("A")
select name;
foreach (var n in query)
{
Console.WriteLine(n);
}
// 输出: Alice, Anna
方法语法(更灵活):
var query = names.Where(name => name.StartsWith("A"));
以下是几个最常用的LINQ方法及其用途:
names.Where(n => n.Length > 4)
names.Select(n => n.ToUpper())
names.OrderBy(n => n)
names.OrderBy(n => n.Length).ThenBy(n => n)
names.Skip(1).Take(3) // 跳过第一个,取三个
names.Any(n => n.StartsWith("B")) // true
names.All(n => n.Length > 1) // true
names.FirstOrDefault(n => n.StartsWith("Z")) // 返回 null
public class Person
{
public string Name { get; set; }
public int Age { get; set; }
}
List<Person> people = new List<Person>
{
new Person { Name = "Alice", Age = 25 },
new Person { Name = "Bob", Age = 30 },
new Person { Name = "Charlie", Age = 35 }
};
// 查询年龄大于28的人名
var result = from p in people
where p.Age > 28
select p.Name;
// 或使用方法语法
var result2 = people.Where(p => p.Age > 28).Select(p => p.Name);
var query = people.Where(p => p.Age > 25);
people.Add(new Person { Name = "Diana", Age = 27 }); // 后续添加也会被包含
foreach (var p in query) { ... } // 此时才执行,会包含Diana
基本上就这些。掌握 Where、Select、OrderBy 和 FirstOrDefault 等基础操作,就能处理大多数集合查询需求。LINQ让代码更清晰,减少手动遍历的繁琐逻辑。不复杂但容易忽略的是延迟执行机制,理解它能避免一些意外bug。
以上就是C# LINQ查询怎么写 C# LINQ to Objects基本查询语法教程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号