在我的 mongoDB 中创建过滤功能的过程中,我使用 c# 的 mongoDB 驱动程序创建了以下查找查询。
return await DefaultCollection
.Find(c => c.vintageInfo.IsVintage
&& c.IsPublished
&& c.AverageRating >= lowerRating
&& filterArray1.Contains(c.filterSearchParameters.Dosage))
.Skip(page * pageSize)
.Limit(pageSize)
.ToListAsync();
Run Code Online (Sandbox Code Playgroud)
这工作完美,一切都很棒!
现在正如我们在上面的例子中看到的,我可以检查提供的 filterArray1 是否包含文档属性 c.filterSearchParameters.Dosage。现在问题出现的原因,该文件进一步包含一个列表如下c.filterSearchParameters.Styles。我希望能够做的是检查列表 c.filterSearchParameters.Styles 是否包含任何匹配 filterArray2 的值。
编辑
按要求:
filterSearchParameters 看起来像:
public class FilterSearchParameters
{
public string Dosage { get; set; }
public List<string> Style { get; set; }
public List<string> Character { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
而 filterArray1 和 2 只是一个普通的:
List<string> filterArray1
List<string> filterArray2
Run Code Online (Sandbox Code Playgroud)
为此,我尝试过:
return await DefaultCollection
.Find(c => …Run Code Online (Sandbox Code Playgroud)