LINQ(Language Integrated Query,语言集成查询)是 C# 中一套内建的、类型安全的数据查询能力,它不是独立工具或库,而是直接嵌入语言的语法和扩展方法体系。它的核心价值在于:用统一、声明式的方式操作各种数据源,不用切换思维模式,也不用拼接字符串查数据库。
LINQ 的三个固定步骤
所有 LINQ 查询都严格遵循三步逻辑,缺一不可:
准备数据源:必须是支持IEnumerable<t></t>或
IQueryable<t></t>的类型,比如
List<int></int>、数组、
string[],甚至 Entity Framework 的
DbSet<customer></customer>;XML 文档经
XElement.Load()后也自动变成可查的
IEnumerable<xelement></xelement>构建查询表达式:此时不执行任何操作,只是定义“要什么”,比如
from x in list where x > 5 select x * 2—— 这行代码运行后得到的是一个
IEnumerable<int></int>对象,不是结果数据 触发执行:只有真正遍历(
foreach)、调用
ToList()、
First()、
Count()等终结方法时,查询才真正运行;这是延迟执行的关键体现
两种写法,本质一样
查询表达式语法(SQL 风格)和方法链语法(点号调用)功能完全等价,编译器会把前者自动转成后者:
查询表达式:适合多步骤、结构清晰的场景,比如带join、
group by、
orderby的复杂查询,读起来接近自然语言 方法链:更贴近 C# 编程习惯,尤其适合动态组合条件(比如根据参数决定是否加
.Where()),也更容易配合 Lambda 表达式做高阶操作
常用操作不是“函数列表”,而是语义组合
LINQ 方法不是孤立的工具,而是按数据处理阶段分层协作:
筛选:用Where(),支持任意布尔表达式,可链式叠加多个条件 投影:用
Select()改变每个元素形态,比如从
Customer只取
Name和
City,生成匿名类型或新类实例 排序与分组:
OrderBy()/
ThenBy()控制顺序;
GroupBy()按键归类,返回
IGrouping<k v></k>序列 聚合:
Count()、
Sum()、
Average()等属于“终结操作”,一调就执行,不返回可枚举对象
别忽略它的底层契约
LINQ 能跨数据源工作,靠的是抽象统一接口:
IEnumerable<t></t>对应内存集合(LINQ to Objects),走的是本地迭代
IQueryable<t></t>对应远程数据源(如数据库),表达式树会被翻译成 SQL 执行,不是先拉全量再过滤 自定义类型只要实现
IEnumerable<t></t>或提供
GetEnumerator(),就能被 LINQ 查询,无需额外适配
基本上就这些。掌握这四块,你就站在了 LINQ 的主干道上,后续学 EF、处理 JSON 或 XML 都只是换数据源而已。
