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 字段的更多信息
我想我已经把自己蒙蔽了,一遍又一遍地盯着错误看,真的可以使用一些输入。我有一组时间序列文件。现在我想找到特定 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 字段的更多信息