LINQ Group По и выберите коллекцию

У меня есть эта структура

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 где-то там, но может сделать с некоторыми указателями.

Ответ 1

Я думаю, вы хотите:

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

... но я лично считаю это менее ясным.

Ответ 2

вам также может понравиться

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

Ответ 3

вы можете выполнить его с помощью группового соединения

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 - элементы заказа клиента.