【发布时间】:2023-03-27 14:13:01
【问题描述】:
Elasticsearch 中有match_phrase 查询,也有wildcard 查询。有没有办法将两者结合起来搜索“foo ba*”之类的内容?
【问题讨论】:
Elasticsearch 中有match_phrase 查询,也有wildcard 查询。有没有办法将两者结合起来搜索“foo ba*”之类的内容?
【问题讨论】:
这个问题的答案在于使用“跨度查询”。正如官方文档中提到的:
Span 查询是低级位置查询,可提供专家控制顺序和指定术语的接近度。
最终的查询看起来像这样:
{
"query": {
"span_near" : {
"clauses" : [
{ "span_term" : { "field" : "foo" } },
{ "span_multi" : { "match": { "wildcard": { "field" : "ba*" } } } }
],
"slop" : 0,
"in_order" : true
}
}
}
注意:
slop 用于提及不同的“跨度项”可以有多远。在这里,由于我们希望它们彼此相邻,因此我们将 slop 指定为 0。in_order 表示术语的顺序是否重要。在我们的例子中,它是 - 因此是 true。【讨论】: