前言
如果需要在 LINQ 查询中指定左侧字段属性值必须包含在右侧的数组中,可以使用 lambda 表达式和 LINQ 的 All 方法来实现。以下是一个示例代码:
示例
假设我们有一个包含订单信息的列表,每个订单信息有订单编号(OrderNumber)和商品列表(Products)两个属性。我们要筛选出商品列表包含 "apple" 和 "banana" 的订单信息。
List<Order> orders = new List<Order>
{
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 是否包含指定的商品名称。