gpt4 book ai didi

c# - Linq 查询一个集合内的集合、来自另一个集合的集合

转载 作者:行者123 更新时间:2023-12-03 21:35:56 25 4
gpt4 key购买 nike

我有类似这个模型的东西:

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

这并不是真正有效。如果 requestedVariationNumbersHashSet 会更好,因为在最坏的情况下会为每个产品的每个变体调用 requestedVariationNumbers.Contains(v.VariationID) ,在最好的情况下会为每个产品的每个第一个变体调用。

关于c# - Linq 查询一个集合内的集合、来自另一个集合的集合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7401174/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com