LINQ Group By并选择收藏


72

我有这个结构

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

Answers:


135

我想你要:

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

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


您是否需要在组上进行ToList()调用?最后一个ToList()不够吗?
乔安娜·德克斯

2
@Joanna:根据OP的要求,Items匿名类型的属性必须为列表。
阿尼(Ani)2012年

您能否为此提供一些帮助:stackoverflow.com/questions/44764687/…–
Si8

6

你可能也喜欢这个

var Grp = Model.GroupBy(item => item.Order.Customer)
      .Select(group => new 
        { 
             Customer = Model.First().Customer, 
             CustomerId= group.Key,  
             Orders= group.ToList() 
       })
      .ToList();

为什么我得到item.Field<>而不是.Order例如?我正在使用数据表。
Si8

2

您可以通过组加入来实现

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是客户的订单项。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.