【问题标题】:MongoDB C# 2.14 Driver Filter.InMongoDB C# 2.14 驱动过滤器.In
【发布时间】:2022-01-03 23:09:27
【问题描述】:

我正在尝试使用Filter.In API 获取文档的数组字段具有匹配值的所有文档。

Filter.In 方法需要 FieldDefinition 和 values 数组,但如果我使用 lambda,那就行不通了。

是这样缩进还是我遇到了某种错误?

我正在尝试一种强类型的方法。

genres = new[] {"one", "two", "three"};
//This filter works
var filter = Builders<Movie>.Filter
    .ElemMatch(movie => movie.Genres, genre => genres.Contains(genre));
//This filter works
var filter2 = Builders<Movie>.Filter.In(nameof(Movie.Genres), genres);
//This filter works
var filter3 = Builders<Movie>.Filter.In("genres", genres);
//Doesn't compile
var filter4 = Builders<Movie>.Filter.In(movie => movie.Genres, genres);

【问题讨论】:

    标签: c# mongodb mongodb-.net-driver


    【解决方案1】:

    In 过滤器检查指定字段的值是否包含在提供的数组中。如果您有一个与电影关联的Genre,则可以使用此过滤器。您会收到编译时错误,因为过滤器生成器希望此字段的类型为 string 而不是 string[]

    要检查您的数组字段是否包含提供的数组中的值,请尝试以下操作:

    var filter = Builders<Movie>.Filter.AnyIn(movie => movie.Genres, genres);
    

    【讨论】:

      猜你喜欢
      • 2021-09-01
      • 1970-01-01
      • 2018-02-04
      • 2016-11-16
      • 1970-01-01
      • 2019-05-13
      • 2021-11-03
      • 2017-08-27
      • 2022-07-19
      相关资源
      最近更新 更多