我有这个结构
Customer
- has many Orders
- has many OrderItems
我想生成一个列表CustomerItems
通过 LINQ 给出的子集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()
...但我个人觉得不太清楚。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)