LINQ分组和选择集合

103

我有这个结构

Customer
 - has many Orders
  - has many OrderItems

我想通过 LINQ 给定 OrderItems 的一个子集来生成 CustomerItems 列表:

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

这是一个客户从商品子集中订购的所有物品的分组,我该如何使用LINQ回溯订单并按客户分组以生成此对象?

到目前为止,我的想法是类似于:

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

但显然那不是一个列表。我猜需要在那里加入SelectMany,但需要一些指导。

3个回答

181

我认为您想要的是:

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

但我个人认为那不够清晰。


你需要在group上调用ToList()吗?最后一个ToList()不足以满足需求吗? - Joanna Derks
2
@Joanna:根据原帖的要求,匿名类型的“Items”属性必须是一个列表。 - Ani
你能为这个问题提供一些帮助吗:https://stackoverflow.com/questions/44764687/how-to-use-linq-to-group-by-and-order-by-certain-column - Si8
似乎在EfCore5中,“group by”甚至在最简单的情况下也不再起作用(例如from la in dbContext.LawArticles group la by new { la.TenantId, la.LawArticleId } into aAgg select new { TenantId = aAgg.Key.TenantId, LawArticleId = aAgg.Key.LawArticleId, ArticleTexts = aAgg.ToList() }),并抱怨“LINQ表达式'GroupByShaperExpression ...无法翻译...” - Alexander
@Alexander,我解决了你的问题。我进行了两个单独的操作:
  1. var list = await _context.SomeTableName.AsNoTracking().ToListAsync()
  2. 我使用 GroupBy 和 Select 作为简单集合。 祝你好运!
- Dmitry Petelko

11

您可能也会喜欢这个

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 ?例如,我正在使用 DataTable。 - Si8

7

您可以使用组合联接来实现此目标。

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代表客户的订单商品。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接