Linq的join

news/2025/10/7 17:30:29/文章来源:https://www.cnblogs.com/johnyang/p/19128659

来给你几个层次递进的 LINQ Join 示例,从最基础的单表连接到多表、对象导航、分组连接全部覆盖。
以下示例均基于 C# + LINQ to Objects(适用于 EF Core / ABP 的仓储查询场景)。


🌱 一、基本示例:两表连接(内连接 Inner Join)

假设你有两个列表:

var users = new List<User>
{new User { Id = 1, Name = "Alice" },new User { Id = 2, Name = "Bob" },new User { Id = 3, Name = "Charlie" }
};var orders = new List<Order>
{new Order { Id = 101, UserId = 1, Product = "Laptop" },new Order { Id = 102, UserId = 1, Product = "Mouse" },new Order { Id = 103, UserId = 2, Product = "Keyboard" }
};

定义实体类:

public class User
{public int Id { get; set; }public string Name { get; set; }
}public class Order
{public int Id { get; set; }public int UserId { get; set; }public string Product { get; set; }
}

✅ 内连接写法(Join)

var query = from u in usersjoin o in orders on u.Id equals o.UserIdselect new{UserName = u.Name,o.Product};foreach (var item in query)
{Console.WriteLine($"{item.UserName} 买了 {item.Product}");
}

输出:

Alice 买了 Laptop
Alice 买了 Mouse
Bob 买了 Keyboard

🌿 二、左连接(Left Join)

如果想保留所有用户,即使他们没有下单,也要出现在结果中(类似 SQL LEFT JOIN):

var query = from u in usersjoin o in orders on u.Id equals o.UserId into userOrdersfrom o in userOrders.DefaultIfEmpty() // 左连接的关键select new{UserName = u.Name,Product = o?.Product ?? "(无订单)"};foreach (var item in query)
{Console.WriteLine($"{item.UserName} - {item.Product}");
}

输出:

Alice - Laptop
Alice - Mouse
Bob - Keyboard
Charlie - (无订单)

🌾 三、多字段连接(Composite Key Join)

有时你要根据多个字段联合匹配:

var recordsA = new[]
{new { UserId = 1, Year = 2024, Score = 90 },new { UserId = 2, Year = 2025, Score = 88 }
};var recordsB = new[]
{new { UserId = 1, Year = 2024, Rank = 1 },new { UserId = 2, Year = 2025, Rank = 2 }
};var query = from a in recordsAjoin b in recordsBon new { a.UserId, a.Year } equals new { b.UserId, b.Year }select new{a.UserId,a.Year,a.Score,b.Rank};foreach (var item in query)Console.WriteLine($"{item.UserId}-{item.Year}: Score={item.Score}, Rank={item.Rank}");

🌻 四、GroupJoin(分组连接)

如果你想把每个用户的订单放进集合中(类似 SQL 的 “Group By + Join”):

var query = from u in usersjoin o in orders on u.Id equals o.UserId into userOrdersselect new{u.Name,Orders = userOrders.ToList()};foreach (var user in query)
{Console.WriteLine($"{user.Name} 的订单:");foreach (var order in user.Orders)Console.WriteLine($"  - {order.Product}");
}

输出:

Alice 的订单:- Laptop- Mouse
Bob 的订单:- Keyboard
Charlie 的订单:(无)

🌺 五、在 EF Core / ABP 仓储中使用

假设你有 ABP 实体:

public class User : Entity<Guid>
{public string Name { get; set; }
}public class Order : Entity<Guid>
{public Guid UserId { get; set; }public string Product { get; set; }
}

仓储查询:

var query =from user in await _userRepository.GetQueryableAsync()join order in await _orderRepository.GetQueryableAsync()on user.Id equals order.UserIdselect new { user.Name, order.Product };var list = await AsyncExecuter.ToListAsync(query);

ABP 的 IRepository.GetQueryableAsync() 返回 EF Core 的 IQueryable<TEntity>
AsyncExecuter.ToListAsync() 是 ABP 内部封装的异步执行器(相当于 await query.ToListAsync())。


✅ 六、总结

类型 描述 关键写法
内连接(Inner Join) 匹配的记录才保留 join ... on ... equals ...
左连接(Left Join) 主表全保留 join ... into ... from ... DefaultIfEmpty()
复合键连接 多字段匹配 on new { a.X, a.Y } equals new { b.X, b.Y }
分组连接 一对多集合 join ... into ... select new { key, group }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/930657.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网站在线解压齐大胜请于果做网站是第几集

折叠屏扫描二维码方案 介绍 本示例介绍使用自定义界面扫码能力在折叠屏设备中实现折叠态切换适配。自定义界面扫码使用系统能力customScan&#xff0c;其提供相机流的初始化、启动扫码、识别、停止扫码、释放相机流资源等能力。折叠屏折叠状态通过监听display的foldStatusCha…

实用指南:工业智能网关保障冷冻仓储设备无人值守安全运行

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

网站建设类别wordpress 应用监测

UE5.1_使用技巧&#xff08;常更&#xff09; 1. 清除所有断点 运行时忘记蓝图中的断点可能会出现运行错误的可能&#xff0c;务必运行是排除一切断点&#xff0c;逐个排查也是办法&#xff0c;但是在事件函数多的情况下会很复杂且慢节奏&#xff0c;学会一次性清除所有很有必…

深喉咙企业网站帮助深圳小程序建设公司

文章目录 一、安装 rpunct二、使用三、下载模型时报错1、报错详情2、报错原因3、解决方案 四、程序运行时报错1、报错详情2、报错原因3、解决方案 五、修改默认缓存路径 一、安装 rpunct pip install rpunct 相关依赖包信息&#xff1a; langdetect1.0.9 pandas1.2.4 simpletr…

实用指南:用PyTorch从零开始编写DeepSeek-V2

实用指南:用PyTorch从零开始编写DeepSeek-V2pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", &qu…

十所高校角逐对话式AI任务机器人挑战赛

十所来自三大洲的高校团队将参与首届融合语音与视觉的多模态对话AI挑战赛,开发能协助完成多步骤烹饪和DIY项目的任务助手,涉及知识表示、常识推理和语言生成等多项AI技术。十所高校团队入选参与Alexa Prize任务机器人…

SCIM漏洞挖掘实战指南

本文深入探讨SCIM协议安全风险,涵盖身份验证绕过、令牌管理漏洞、用户重配置缺陷等实战案例,帮助安全研究人员发现和利用企业身份管理系统中的关键漏洞。SCIM Hunting - Beyond SSO 2025年5月8日 - 发布于 Francesco…

网站行业阿里云备案

下载 官网&#xff1a; http://tomcat.apache.org/ 2.安装 默认 3.安装成功

做网站大概多少钱四川企业网站开发

今天在整理JAVA基础知识时发现几大基本数据类型的封装类都有其BYTES值,也就是位数,除了Boolean。特意查了下资料,发现有几大说法,如下&#xff1a; 1.单个的boolean 类型变量在编译的时候是使用的int 类型。 boolean atrue;//这个a在JVM中占4个字节即&#xff1a;32位。 2.bo…

虚拟文件系统

虚拟文件系统 1.向上层用户进程提供统一标准的系统调用接口,屏蔽底层具体文件系统的实现差异 2.要求下层的文件系统必须实现某些规定的函数功能。open/read/write统一使用vnode来存储下层文件系统的目录项 vnode只存在…

博客迁移至CSDN!!!

我的csdn主页:https://blog.csdn.net/2301_80265763

博客迁移到CSDN!!!

我的csdn主页:https://blog.csdn.net/2301_80265763

湖北住房与城乡建设厅网站wordpress前台出现旧版文件夹

信息打点——前端JS框架 文章目录 信息打点——前端JS框架小节概述-思维导图JS安全概述什么是JS渗透测试&#xff1f;前后端差异JS安全问题流行的Js框架如何判定JS开发应用&#xff1f; 测试方法&#xff08;JS文件的获取以及分析方法1、手工搜索分析2、半自动Burp分析插件介绍…

手动实现一个C++绑定Lua脚本的库

手动实现一个C++绑定Lua脚本的库把C++绑定到Lua脚本的方法很多。但是在C++11之前,都没有太好的办法。比如tolua++,这个工具需要手动编写额外的pkg文件,每次需要手动执行命令生成额外的C++文件,使用比较繁琐,所以逐…

代码随想录算法训练营第十天 | leetcode 232 225 20 1047

用栈实现队列 整体思路:使用两个栈一个当作入栈,一个当作出栈,当队列需要出队列的时候,将入栈的元素,倒序放入出栈里面,对出栈进行pop操作即可,若需要获得队头元素,同理,执行出栈peek操作即可,判断队列是否为…

重庆永川网站建设公司广东个人备案网站内容

SQL RDBMS 概念 RDBMS是关系数据库管理系统(Relational Database Management System)的缩写。 RDBMS是SQL的基础&#xff0c;也是所有现代数据库系统(如MS SQL Server、IBMDB2、Oracle、MySQL和MicrosoftAccess)的基础。 关系数据库管理系统(Relational Database Management Sy…

深入解析:黑马k8s(十七)

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

怎么做下载类的网站课程平台网站建设报价

Gateway整合Sentinel ​ 前面使用过Sentinel组件对服务提供者、服务消费者进行流控、限流等操作。除此之外&#xff0c;Sentinel还支持对Gateway、Zuul等主流网关进行限流。 ​ 自sentinel1.6.0版开始&#xff0c;Sentinel提供了Gateway的适配模块&#xff0c;能针对路由(rou…

openJDK历史版本

https://jdk.java.net/archive/

2025冲压件厂家权威推荐榜:冲压件/新能源冲压件/光伏冲压件/精密冲压件/异形冲压件/五金冲压件/铝冲压件/汽配冲压件/不锈钢冲压件/家具冲压件厂家公司精密制造与品质保障实力之选

行业背景分析随着制造业向高端化、智能化方向转型升级,冲压件作为基础零部件在汽车制造、电子设备、家电产品等领域的应用日益广泛。2025年,中国冲压件市场规模预计将突破5000亿元,行业竞争格局呈现专业化、精细化发…