我有类似这个模型的东西:
public class Product
{
public int ID { get; set; }
public string Name { get; set; }
public ICollection<ProductVariation> Variations { get; set; }
}
public class ProductVariation
{
public int VariationID { get; set; }
public string Size { get; set; }
public bool InStock { get; set; }
}
我有一个产品列表 - 称为“availableProducts”
List<Product> availableProducts;
然后我还有一个 int - requestVariationNumbers 列表:
List<int> requestedVariationNumbers;
我想要做的是从 availableProducts 获取产品,其中 Product.Variations 集合包含 requestedVariationNumbers 中的 VariationID。
到目前为止,我已经得到了这个: (由 ReSharper 基于一系列丑陋的 foreach 语句生成...)
对我来说这似乎“肮脏”......
var result = (
from rvn in requestedVariationNumbers
from product in availableProducts
from itemVariation in product.ItemVariations
where itemVariation.ItemNo == rvn
select product)
.ToList();
最佳答案
试试这个:
var result = availableProducts.Where(p => p.Variations
.Any(v => requestedVariationNumbers
.Contains(v.VariationID)));
这并不是真正有效。如果 requestedVariationNumbers
是 HashSet
会更好,因为在最坏的情况下会为每个产品的每个变体调用 requestedVariationNumbers.Contains(v.VariationID)
,在最好的情况下会为每个产品的每个第一个变体调用。
关于c# - Linq 查询一个集合内的集合、来自另一个集合的集合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7401174/