89

我有这个结构

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,但可以使用一些指针。

4

3 回答 3

160

我想你想要:

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() 

...但我个人觉得不太清楚。

于 2012-05-17T14:38:36.133 回答
6

你可能也喜欢这个

var Grp = Model.GroupBy(item => item.Order.Customer)
      .Select(group => new 
        { 
             Customer = Model.First().Customer, 
             CustomerId= group.Key,  
             Orders= group.ToList() 
       })
      .ToList();
于 2016-08-08T15:26:53.900 回答
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});

c 是客户,g 是客户订购的商品。

于 2015-11-21T09:57:36.167 回答