LINQ 分组依据,然后选择集合
本文关键字:然后 选择 集合 LINQ | 更新日期: 2023-09-27 18:34:34
我有这个结构
Customer
- has many Orders
- has many OrderItems
我想通过 LINQ 生成一个CustomerItems
列表,给定一个OrderItems
子集:
List of new { Customer, List<OrderItem> Items }
这是客户从项目子集中订购的所有项目的分组
如何使用 LINQ 回溯订单并按客户分组以生成此对象?
到目前为止,我正在做类似的事情
items
.GroupBy(i => i, i => i.Order.Customer, (i, customer) => new {customer, i})
但这显然不是一个列表。我猜我需要在某个地方有一个 SelectMany,但可以使用一些指针。
我想你想要:
items.GroupBy(item => item.Order.Customer)
.Select(group => new { Customer = group.Key, Items = group.ToList() })
.ToList()
如果要继续使用当前正在使用的重载GroupBy
,可以执行以下操作:
items.GroupBy(item => item.Order.Customer,
(key, group) => new { Customer = key, Items = group.ToList() })
.ToList()
。但我个人觉得不太清楚。
你可能也喜欢这个
var Grp = Model.GroupBy(item => item.Order.Customer)
.Select(group => new
{
Customer = Model.First().Customer,
CustomerId= group.Key,
Orders= group.ToList()
})
.ToList();
你可以通过组加入来实现它
var result = (from c in Customers
join oi in OrderItems on c.Id equals oi.Order.Customer.Id into g
Select new { customer = c, orderItems = g});
c 是客户,g 是客户订购的项目。