Entity Framework Core怎么使用LINQ EF Core Lambda表达式查询方法

来源:这里教程网 时间:2026-02-21 17:37:40 作者:

Entity Framework Core 中使用 LINQ 和 Lambda 表达式查询,核心是通过

DbSet<t></t>
提供的扩展方法(如
Where
Select
OrderBy
等)配合 Lambda 表达式来构建类型安全、可组合的查询。EF Core 会将这些表达式树翻译成 SQL,在数据库端执行,而不是在内存中处理。

基础查询:Where + Lambda 过滤数据

最常用的是用

Where
方法配合 Lambda 表达式做条件筛选。Lambda 参数代表集合中的单个实体,返回
bool
值决定是否保留该条目。

例如查所有状态为 "Active" 的用户:

var activeUsers = context.Users.Where(u => u.Status == "Active").ToList();

注意:

Where
返回的是
IQueryable<user></user>
,不会立即执行;调用
ToList()
FirstOrDefault()
等终结方法才会触发 SQL 查询。

链式组合:多条件与复杂逻辑

Lambda 表达式支持 &&、||、!、括号分组,也支持导航属性访问(只要关系已正确配置),EF Core 能将其转为 JOIN 或子查询。

多个条件用
&&
(对应 SQL AND):
Where(u => u.IsActive && u.CreatedDate > DateTime.Today.AddDays(-7))
模糊匹配用
Contains
(生成 LIKE %...%):
Where(u => u.Name.Contains("张"))
关联查询(如查用户及其订单):
context.Users.Where(u => u.Orders.Any(o => o.Total > 100))
空值安全写法:
Where(u => u.Email != null && u.Email.EndsWith("@gmail.com"))

投影与转换:Select + Lambda 提取字段

Select
配合 Lambda 可只取需要的字段或构造新对象(匿名类型或 DTO),减少网络传输和内存占用。

例如只取用户名和邮箱:

var namesAndEmails = context.Users
    .Where(u => u.IsActive)
    .Select(u => new { u.Name, u.Email })
    .ToList();

也可以映射到已定义的类(需确保构造函数或属性可被 EF Core 解析):

.Select(u => new UserSummary { Name = u.Name, Email = u.Email })

排序、分页与聚合:OrderBy、Skip/Take、Count 等

这些方法同样接受 Lambda 表达式指定排序键或聚合依据:

升序:
OrderBy(u => u.CreatedDate)
;降序:
OrderByDescending(u => u.Score)
分页(跳过前 20 条,取下 10 条):
Skip(20).Take(10)
统计数量:
Count(u => u.Status == "Inactive")
(生成 COUNT(*) WHERE ...)
是否存在:
Any(u => u.Email == inputEmail)
(生成 EXISTS 或 SELECT 1)

注意:分页必须配合排序使用(否则结果不稳定),且

Skip
/
Take
在 SQL Server/PostgreSQL 中会被翻译为
OFFSET FETCH
LIMIT OFFSET
,MySQL 8.0+ 同样支持。

基本上就这些。关键点是——Lambda 写在

IQueryable
上,EF Core 才能翻译;一旦调用了
AsEnumerable()
ToList()
,后续操作就在内存中进行,无法利用数据库能力。

相关推荐