问题描述
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
。