在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 来定义不同的结果结构。