Return 来自 Elasticsearch 和 NEST 的 id 以下五个文档

Return five following documents from an id with Elasticsearch and NEST

我想我已经把自己蒙蔽了,一遍又一遍地盯着错误看,真的可以使用一些输入。我有一组时间序列文件。现在我想找到特定 id 之后的五个文档。我首先获取该单个文档。然后抓取下面五个没有这个id的文档:

var documents = client.Search<Document>(s => s
    .Query(q => q
        .ConstantScore(cs => cs
            .Filter(f => f
                .Bool(b => b
                    .Must(must => must
                        .DateRange(dr => dr.Field(field => field.Time).GreaterThanOrEquals(startDoc.Time))
                    .MustNot(mustNot => mustNot
                        .Term(term => term.Id, startDoc.Id))
                    ))))
    .Take(5)
    .Sort(sort => sort.Ascending(asc => asc.Time))).Documents;

我的问题是虽然返回了 5 个文档并正确排序,但起始文档在返回的数据中。我正在尝试使用 must not 过滤器过滤掉它,但似乎没有用。我很确定我在其他地方也这样做过,所以这可能是一个我根本看不到的小问题:)

这是 NEST 生成的查询:

{
   "query":{
      "constant_score":{
         "filter":{
            "bool":{
               "must":[
                  {
                     "range":{
                        "time":{
                           "gte":"2020-08-31T10:47:12.2472849Z"
                        }
                     }
                  }
               ],
               "must_not":[
                  {
                     "term":{
                        "id":{
                           "value":"982DBC1BE9A24F0E"
                        }
                     }
                  }
               ]
            }
         }
      }
   },
   "size":5,
   "sort":[
      {
         "time":{
            "order":"asc"
         }
      }
   ]
}

之所以会发生这种情况,是因为 id 字段可能是经过分析的字段。分析的字段被标记化。有一个 non-analyzed 版本,用于完全匹配(就像你在评论中提到的那样,你有一个)并在你的过滤器中使用它会修复你看到的差异。

关于已分析字段与 non-analyzed 字段的更多信息