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

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

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

  • Join 方法用于将两个集合中的元素根据指定的键相匹配,并返回一个新的结果集。
  • 该方法接受四个参数:内部集合、外部集合、内部键选择器和外部键选择器。
  • 返回的结果集会包含一个元祖,包含内部集合和外部集合匹配的元素。
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 方法也将两个集合中的元素根据指定的键匹配,但它会将匹配的元素分组,并返回一个嵌套集合。
  • 该方法接受四个参数:内部集合、外部集合、内部键选择器、外部键选择器和结果选择器。
  • 结果集将是一个包含内部集合和外部集合匹配元素的集合。
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 方法用于生成一个嵌套结果集。

相关推荐

  1. c# Enumerable<TGroupJoin方法Join区别

    2024-04-26 12:32:03       15 阅读
  2. ThreadLocalSynchronized区别

    2024-04-26 12:32:03       46 阅读
  3. MySQL中 inexists区别

    2024-04-26 12:32:03       18 阅读
  4. CSS transitionanimation区别

    2024-04-26 12:32:03       12 阅读
  5. jQuery —— ajaxFormajaxSubmit区别

    2024-04-26 12:32:03       38 阅读
  6. C# action,delegate,func区别

    2024-04-26 12:32:03       29 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-26 12:32:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-26 12:32:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-26 12:32:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-26 12:32:03       18 阅读

热门阅读

  1. sql优化

    2024-04-26 12:32:03       12 阅读
  2. 第7章 面向对象基础-下(内部类)

    2024-04-26 12:32:03       14 阅读
  3. Apache Spark 的基本概念

    2024-04-26 12:32:03       15 阅读
  4. 服务器镜像是什么

    2024-04-26 12:32:03       13 阅读
  5. 无叶风扇32位MCU单片机MM32SPIN0230

    2024-04-26 12:32:03       13 阅读
  6. jenkins自动化工具简介

    2024-04-26 12:32:03       14 阅读
  7. 强化学习Thompson Sampling策略笔记

    2024-04-26 12:32:03       14 阅读
  8. 探秘STM32MDK:编译过程与文件类型解析

    2024-04-26 12:32:03       14 阅读