0

0

C# 如何在LINQ中使用Join - 连接两个数据源

畫卷琴夢

畫卷琴夢

发布时间:2026-01-23 11:13:02

|

954人浏览过

|

来源于php中文网

原创

LINQ 的 Join 实现内连接,需传入内集合、外键选择器、内键选择器和结果选择器四个参数,仅支持等值匹配且键类型必须一致,性能优于嵌套循环。

c# 如何在linq中使用join - 连接两个数据源

在 C# 的 LINQ 中,Join 用于对两个数据源(如集合)基于键进行内连接(inner join),类似 SQL 的 INNER JOIN。它不支持左连接或全连接,但可通过 GroupJoin 配合 DefaultIfEmpty() 实现。

基本语法:Join 的四个参数

Join 方法需要传入四个关键参数:

  • 内集合(inner):被连接的第二个数据源(如 orders
  • 外键选择器(outerKeySelector):从外集合中提取用于匹配的键(如 customer => customer.Id
  • 内键选择器(innerKeySelector):从内集合中提取用于匹配的键(如 order => order.CustomerId
  • 结果选择器(resultSelector):定义连接后如何组合两条记录(如 (c, o) => new { c.Name, o.OrderDate }

简单示例:连接客户和订单

假设有两个列表:

var customers = new List
{
    new Customer { Id = 1, Name = "张三" },
    new Customer { Id = 2, Name = "李四" }
};

var orders = new List { new Order { Id = 101, CustomerId = 1, OrderDate = DateTime.Today }, new Order { Id = 102, CustomerId = 1, OrderDate = DateTime.Today.AddDays(-1) } };

执行连接:

var result = customers.Join(
    orders,
    c => c.Id,           // 外键:客户ID
    o => o.CustomerId,    // 内键:订单中的客户ID
    (c, o) => new { c.Name, o.OrderDate }  // 结果:匿名对象
);

输出会包含两条记录(因为只有客户 1 有订单),客户 2 不会出现——这是内连接特性。

使用 Join 注意的关键点

键类型必须一致:外键和内键返回的类型需相同或可隐式转换(如 int 与 long 不行,需显式转换)。

android rtsp流媒体播放介绍 中文WORD版
android rtsp流媒体播放介绍 中文WORD版

本文档主要讲述的是android rtsp流媒体播放介绍;实时流协议(RTSP)是应用级协议,控制实时数据的发送。RTSP提供了一个可扩展框架,使实时数据,如音频与视频,的受控、点播成为可能。数据源包括现场数据与存储在剪辑中数据。该协议目的在于控制多个数据发送连接,为选择发送通道,如UDP、组播UDP与TCP,提供途径,并为选择基于RTP上发送机制提供方法。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看

下载

只支持等值连接:LINQ 的 Join 仅支持 == 匹配,不支持 >Contains 等复杂条件;如需非等值逻辑,改用 Where + from ... from ... where 查询表达式。

性能较优:底层会将内集合构建成哈希表,时间复杂度接近 O(n+m),比嵌套循环高效。

替代写法:查询表达式语法(更直观)

上面的连接也可写成:

var result = from c in customers
             join o in orders on c.Id equals o.CustomerId
             select new { c.Name, o.OrderDate };

语义完全等价,on ... equals ... 是固定语法,不能写成 == 或其他操作符。

基本上就这些。掌握 Join 的四个参数含义和等值匹配限制,就能稳妥完成大多数集合关联需求。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

685

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

323

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

348

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1117

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

359

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

717

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

577

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

419

2024.04.29

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

2

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号