c# Enumerable<T>的GroupJoin方法和Join的用法和区别

在 C# 中,Enumerable<T> 类提供了 Join 方法和 GroupJoin 方法,用于对两个集合进行连接操作。这两个方法的用法和区别如下:

Join 方法: 相当于 sql中的inner join

  • Join 方法用于将两个集合中的元素根据指定的键相匹配,并返回一个新的结果集。
  • 该方法接受四个参数:内部集合、外部集合、内部键选择器和外部键选择器。
  • 返回的结果集会包含一个元祖,包含内部集合和外部集合匹配的元素。
c# 复制代码
var persons = new List<Person> { new Person { Id = 1, Name = "Alice" }, new Person { Id = 2, Name = "Bob" } };
var orders = new List<Order> { new Order { PersonId = 1, Amount = 100 }, new Order { PersonId = 2, Amount = 200 } };

var result = persons.Join(orders, person => person.Id, order => order.PersonId, (person, order) => new { person.Name, order.Amount });

// 结果集:{ Name = "Alice", Amount = 100 }, { Name = "Bob", Amount = 200 }

GroupJoin 方法: 相当于 sql的 left join

  • GroupJoin 方法也将两个集合中的元素根据指定的键匹配,但它会将匹配的元素分组,并返回一个嵌套集合。
  • 该方法接受四个参数:内部集合、外部集合、内部键选择器、外部键选择器和结果选择器。
  • 结果集将是一个包含内部集合和外部集合匹配元素的集合。
c# 复制代码
var persons = new List<Person> { new Person { Id = 1, Name = "Alice" }, new Person { Id = 2, Name = "Bob" } };
var orders = new List<Order> { new Order { PersonId = 1, Amount = 100 }, new Order { PersonId = 2, Amount = 200 } };

var result = persons.GroupJoin(orders, person => person.Id, order => order.PersonId, (person, order) => new
{
    Name = person.Name,
    Orders = order
});

// 结果集:{ Name = "Alice", Orders = { Amount = 100 } }, { Name = "Bob", Orders = { Amount = 200 } }

总的来说,Join 方法用于生成一个扁平结果集,GroupJoin 方法用于生成一个嵌套结果集。

相关推荐
mudtools15 小时前
.NET驾驭Word之力:理解Word对象模型核心 (Application, Document, Range)
c#·.net
大飞pkz21 小时前
【设计模式】C#反射实现抽象工厂模式
设计模式·c#·抽象工厂模式·c#反射·c#反射实现抽象工厂模式
唐青枫1 天前
从入门到进阶:C#.NET Stopwatch 计时与性能测量全攻略
c#·.net
未来之窗软件服务1 天前
幽冥大陆(二)RDIFSDK 接口文档:布草洗涤厂高效运营的技术桥梁C#—东方仙盟
开发语言·c#·rdif·仙盟创梦ide·东方仙盟
1uther1 天前
Unity核心概念⑨:Screen
开发语言·游戏·unity·c#·游戏引擎
阿幸软件杂货间1 天前
Office转PDF转换器v1.0.py
开发语言·pdf·c#
sali-tec1 天前
C# 基于halcon的视觉工作流-章34-环状测量
开发语言·图像处理·算法·计算机视觉·c#
Tiger_shl1 天前
【层面一】C#语言基础和核心语法-02(反射/委托/事件)
开发语言·c#
mudtools2 天前
.NET驾驭Word之力:COM组件二次开发全攻略之连接Word与创建你的第一个自动化文档
后端·c#
王维志2 天前
LiteDB详解
数据库·后端·mongodb·sqlite·c#·json·database