Linq Grouper par et sélectionner collection

, j'ai cette structure

Customer
 - has many Orders
  - has many OrderItems

Je veux générer une liste de CustomerItems via LINQ donné un sous-ensemble de OrderItems:

List of new { Customer, List<OrderItem> Items }

Qui est un regroupement de tous les articles qu'un client a commandés à partir du sous-ensemble d'articles

Comment puis-je utiliser LINQ pour retracer la commande et le groupe par client pour générer cet objet?

Jusqu'à présent, je suis sur quelque chose comme

items
 .GroupBy(i => i, i => i.Order.Customer, (i, customer) => new {customer, i})

Mais ce n'est évidemment pas une liste. Je suppose que j'ai besoin D'un SelectMany quelque part, mais pourrait faire avec certains pointeur.

42
demandé sur Ani 2012-05-17 18:33:04

3 réponses

Je pense que vous voulez:

items.GroupBy(item => item.Order.Customer)
     .Select(group => new { Customer = group.Key, Items = group.ToList() })
     .ToList() 

Si vous souhaitez continuer à utiliser la surcharge de GroupBy que vous utilisez actuellement, vous pouvez faire:

items.GroupBy(item => item.Order.Customer, 
              (key, group) =>  new { Customer = key, Items = group.ToList() })
     .ToList() 

...mais personnellement, je trouve cela moins clair.

80
répondu Ani 2015-11-05 14:56:11

Vous pouvez aussi aimer ceci

var Grp = Model.GroupBy(item => item.Order.Customer)
      .Select(group => new 
        { 
             Customer = Model.First().Customer, 
             CustomerId= group.Key,  
             Orders= group.ToList() 
       })
      .ToList();
3
répondu caras 2016-08-08 15:26:53

Vous pouvez le réaliser avec group join

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 est Client et g est les articles de commande des clients.

2
répondu cimey 2015-11-21 09:57:36