我有这个结构
Customer
- has many Orders
- has many OrderItems
Run Code Online (Sandbox Code Playgroud)
我想生成一个CustomerItemsvia LINQ 列表给出一个子集OrderItems:
List of new { Customer, List<OrderItem> Items }
Run Code Online (Sandbox Code Playgroud)
这是客户从商品子集中订购的所有商品的分组
我如何使用LINQ来跟踪客户的订单和分组以生成此对象?
到目前为止,我有点像
items
.GroupBy(i => i, i => i.Order.Customer, (i, customer) => new {customer, i})
Run Code Online (Sandbox Code Playgroud)
但那显然不是列表.我猜我在那里需要一个SelectMany,但是可以用一些指针来做.
Ani*_*Ani 103
我想你想要:
items.GroupBy(item => item.Order.Customer)
.Select(group => new { Customer = group.Key, Items = group.ToList() })
.ToList()
Run Code Online (Sandbox Code Playgroud)
如果你想继续使用GroupBy你目前正在使用的超载,你可以这样做:
items.GroupBy(item => item.Order.Customer,
(key, group) => new { Customer = key, Items = group.ToList() })
.ToList()
Run Code Online (Sandbox Code Playgroud)
......但我个人觉得不太清楚.
你可能也喜欢这个
var Grp = Model.GroupBy(item => item.Order.Customer)
.Select(group => new
{
Customer = Model.First().Customer,
CustomerId= group.Key,
Orders= group.ToList()
})
.ToList();
Run Code Online (Sandbox Code Playgroud)
小智 5
你可以通过加入群组来实现
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});
Run Code Online (Sandbox Code Playgroud)
c 是客户,g 是客户订购的商品。
| 归档时间: |
|
| 查看次数: |
157482 次 |
| 最近记录: |