LINQ Group By和select系列

jen*_*ent 56 c# linq group-by

我有这个结构

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)

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

  • @Joanna:根据OP的要求,匿名类型的`Items`属性必须是一个列表. (2认同)

car*_*ras 6

你可能也喜欢这个

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 是客户订购的商品。