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