【C#】LINQ

LINQ

LINQ(语言集成查询)是C#和VB.NET中的统一查询语法,用于从不同的源和格式检索数据。它集成在C#或VB中,从而消除了编程语言和数据库之间的不匹配,并为不同类型的数据源提供了单个查询接口。

LINQ查询语法

LINQ的查询语法与SQL相同,以from子句开头,可以以select或groupby子句结尾。

csharp 复制代码
var result = from product in products
             where product.Price > 100
             orderby product.Name
             select product;

比较适合复杂的多表连接查询、分表查询、可读性好。

LINQ方法语法

方法语法(也称为连贯语法)使用Enumerable 或 Queryable静态类中包含的扩展方法。方法语法包括扩展方法和 Lambda 表达式。

csharp 复制代码
var result = products
    .Where(product => product.Price > 100)
    .OrderBy(product => product.Name);

适合简单的单表操作,使用某些只有方法语法的操作符(如First(), Single()等)。

以上两者在性能上没有区别,因为查询语句在编译时会被转换为对应的方法调用。

嵌入委托方法

可以通过委托来描述筛选条件,方便复用。

csharp 复制代码
// 定义委托
Func<Student, bool> isTeenager = s => s.Age > 12 && s.Age < 20;

// 使用方法语法调用
var teenStudents = students.Where(isTeenager)
                          .OrderBy(s => s.Name)
                          .ToList();

// 可以在多个地方复用
var teenCount = students.Count(isTeenager);
var firstTeen = students.FirstOrDefault(isTeenager);
var teenStudents = from s in students where isTeenager(s) select s;

完整的LINQ查询方式矩阵

查询方式 委托变量 内联条件
查询语法 from s in students where isTeenager(s) select s from s in students where s.Age>12 select s
方法语法 students.Where(isTeenager) students.Where(s => s.Age>12)

拓展文章

  1. 菜鸟教程LINQ讲解
相关推荐
嘿嘿嘿x3几秒前
Linux记录过程
linux·开发语言
默 语9 分钟前
Records、Sealed Classes这些新特性:Java真的变简单了吗?
java·开发语言·python
止观止9 分钟前
拥抱 ESNext:从 TC39 提案到生产环境中的现代 JS
开发语言·javascript·ecmascript·esnext
卷心菜狗19 分钟前
Python进阶-深浅拷贝辨析
开发语言·python
时寒的笔记20 分钟前
js逆向7_案例惠nong网
android·开发语言·javascript
Evand J37 分钟前
【MATLAB例程】基于低精度IMU、GNSS的UAV初始航向(三维角度)校准的仿真,包含卡尔曼滤波、惯导解算与校正
开发语言·matlab·gnss·imu·卡尔曼滤波
feng_you_ying_li43 分钟前
c++之哈希表的介绍与实现
开发语言·c++·散列表
网域小星球1 小时前
C 语言从 0 入门(十四)|文件操作:读写文本、保存数据持久化
c语言·开发语言·文件操作·fopen·fprintf
网域小星球1 小时前
C 语言从 0 入门(七)|字符数组与字符串完整精讲|VS2022 高质量实战
c语言·开发语言·字符串·vs2022·字符数组
Jia ming1 小时前
C语言实现日期天数计算
c语言·开发语言·算法