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(),后续操作就在内存中进行,无法利用数据库能力。
