Linq内部加入组,然后选择组,为什么有空组?

ldioqlga  于 2023-01-06  发布在  其他
关注(0)|答案(1)|浏览(118)

我试图得到一个客户名单与他们各自的订单,但如果客户没有任何订单,他们应该从这个名单中排除。

var customerOrders = (from customer in customers
            join order in orders on customer.CustomerId equals order.CustomerId into
                orderGroup
            select new
            {
                Customer.CustomerId,
                Orders = orderGroup.ToList()
            }).ToList();

在customerOrders列表中,我得到了没有订单或订单列表为空的客户。
我怎么能只得到有订单的客户?

ssm49v7z

ssm49v7z1#

使用where orderGroup.Any()

var customerOrders =
(
    from customer in customers
    join order in orders on customer.CustomerId equals order.CustomerId into orderGroup
    where orderGroup.Any()
    select new
    {
        customer.CustomerId,
        Orders = orderGroup.ToList()
    }
).ToList();

group order by customer.CustomerId into g

var customerOrders =
(
    from customer in customers
    join order in orders on customer.CustomerId equals order.CustomerId
    group order by customer.CustomerId into g
    select new
    {
        CustomerId = g.k,
        Orders = g.ToList()
    }
).ToList();

相关问题