C#开发-集合使用和技巧(九)Join的用法

在C#中,IEnumerable 的 Join 方法用于根据键将两个序列中的元素进行关联。Join 方法通常用于执行类似于 SQL 中的内连接操作。以下是 Join 方法的基本用法:

基本语法

csharp 复制代码
public static IEnumerable<TResult> Join<TOuter, TInner, TKey, TResult>(
    this IEnumerable<TOuter> outer,
    IEnumerable<TInner> inner,
    Func<TOuter, TKey> outerKeySelector,
    Func<TInner, TKey> innerKeySelector,
    Func<TOuter, TInner, TResult> resultSelector
)

参数说明

• outer: 外部数据源。

• inner: 内部数据源。

• outerKeySelector: 一个函数,用于从外部数据源的每个元素提取键。

• innerKeySelector: 一个函数,用于从内部数据源的每个元素提取键。

• resultSelector: 一个函数,用于定义结果投影。

示例

假设我们有两个集合,一个是学生集合,另一个是成绩集合,我们希望根据学生的ID将这两个集合关联起来。

定义测试用的数据类

csharp 复制代码
    /// <summary>
    /// 学生信息
    /// </summary>
    public class Student
    {
        public int Id { get; set; }
        public string Name { get; set; }
    }

    /// <summary>
    /// 学生成绩
    /// </summary>
    public class Grade
    {
        public int StudentId { get; set; }

        /// <summary>
        /// 科目
        /// </summary>
        public string Subject { get; set; }

        /// <summary>
        /// 成绩
        /// </summary>
        public int Score { get; set; }
    }

创建数据

csharp 复制代码
  var students = new List<Student>
  {
      new Student { Id = 1, Name = "张三" },
      new Student { Id = 2, Name = "李四" },
      new Student { Id = 3, Name = "王五" },
  };

  var grades = new List<Grade>
  {
      new Grade
      {
          StudentId = 1,
          Subject = "数学",
          Score = 90,
      },
      new Grade
      {
          StudentId = 2,
          Subject = "科学",
          Score = 85,
      },
      new Grade
      {
          StudentId = 1,
          Subject = "历史",
          Score = 88,
      },
  };

使用 Join 方法

在存储数据时,都是通过ID来确定唯一性,不会重复存储Name之类的,而在使用的时候,显示在界面上,用户不知道ID的意义,则需要显示Name。

在代码中就需要处理,使用Join方法,返回学生跟成绩关联信息,可以知道谁什么课考了多少分。

csharp 复制代码
var studentGrades = students.Join(
    grades,
    student => student.Id,
    grade => grade.StudentId,
    (student, grade) => new
    {
        StudentName = student.Name,
        GradeSubject = grade.Subject,
        GradeScore = grade.Score
    });

foreach (var sg in studentGrades)
{
    Console.WriteLine($"Student: {sg.StudentName}, Subject: {sg.GradeSubject}, Score: {sg.GradeScore}");
}

运行测试

在这个示例中,我们使用 Join 方法将 students 和 grades 集合根据学生的ID进行了关联,并创建了一个匿名对象来存储结果。你可以根据需要调整 resultSelector 来定义不同的结果结构。

官方文档

https://learn.microsoft.com/zh-cn/dotnet/api/system.linq.enumerable.join?view=net-9.0&redirectedfrom=MSDN#overloads

相关推荐
唐青枫7 分钟前
LinqToDB 从入门到精通:示例驱动教程
c#·.net
望获linux2 小时前
【Linux基础知识系列】第一百一十篇 - 使用Nmap进行网络安全扫描
java·linux·开发语言·前端·数据库·信息可视化·php
雷达学弱狗5 小时前
链式法则解释上游梯度应用
开发语言·前端·javascript
小清兔9 小时前
c#基础知识
开发语言·数据库·学习·unity·c#·游戏引擎·.net
奇某人10 小时前
【语法】【C+V】本身常用图表类型用法快查【CSDN不支持,VSCODE可用】
开发语言·vscode·markdown·mermaid
做一位快乐的码农10 小时前
php程序设计之基于PHP的手工艺品销售网站/基于php在线销售系统/基于php在线购物商城系统
开发语言·php
@珍惜一生@11 小时前
Qt开源库
开发语言·qt·开源
Slaughter信仰11 小时前
深入理解Java虚拟机:JVM高级特性与最佳实践(第3版)第四章知识点问答补充及重新排版
java·开发语言·jvm
心灵宝贝11 小时前
Mac用户安装JDK 22完整流程(Intel版dmg文件安装指南附安装包下载)
java·开发语言·macos
secondyoung11 小时前
一文丝滑使用Markdown:从写作、绘图到转换为Word与PPT
开发语言·vscode·编辑器·powerpoint·markdown·visual studio·mermaid