在 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
方法用于生成一个嵌套结果集。