【.net core】 左侧list某字段属性值必须包含在右侧list的数组中,可以使用 lambda 表达式和 LINQ 的 All 方法来实现

前言

如果需要在 LINQ 查询中指定左侧字段属性值必须包含在右侧的数组中,可以使用 lambda 表达式和 LINQ 的 All 方法来实现。以下是一个示例代码:

示例   

假设我们有一个包含订单信息的列表,每个订单信息有订单编号(OrderNumber)和商品列表(Products)两个属性。我们要筛选出商品列表包含 "apple" 和 "banana" 的订单信息。

List orders = new List
{
    new Order { OrderNumber = "001", Products = new string[] { "apple", "banana", "orange" } },
    new Order { OrderNumber = "002", Products = new string[] { "orange", "pear" } },
    new Order { OrderNumber = "003", Products = new string[] { "apple", "banana" } }
};

string[] includedProducts = new string[] { "apple", "banana" };

var result = orders.Where(o => includedProducts.All(ip => o.Products.Contains(ip)));

foreach (var order in result)
{
    Console.WriteLine(order.OrderNumber);
}

在上面的代码中,我们使用 lambda 表达式 o => includedProducts.All(ip => o.Products.Contains(ip)) 来指定筛选条件。其中,o 表示列表中的每一个订单信息,o.Products 表示该订单信息的商品列表属性,includedProducts 表示右侧的数组,All 方法表示必须所有的 includedProducts 元素都包含在 o.Products 中,Contains 方法表示 o.Products 是否包含指定的商品名称。

你可能感兴趣的:(.Net,Core,linq,.netcore,c#)