我想实现一个商店名称搜索功能,现在如果我写一个商店名称“nite out”,那么我希望我的结果也包含所有子字符串“nite”和“out”和“nite out”。
我尝试使用前缀查询,但无法执行。我听说过模糊查询,但不知道它能否解决我的问题。
谁能告诉我应该使用哪个 ES 查询在顶部获得“nite out”匹配结果,其余“nite”和“out”结果也在“nite out”匹配结果下方。
我想实现一个商店名称搜索功能,现在如果我写一个商店名称“nite out”,那么我希望我的结果也包含所有子字符串“nite”和“out”和“nite out”。
我尝试使用前缀查询,但无法执行。我听说过模糊查询,但不知道它能否解决我的问题。
谁能告诉我应该使用哪个 ES 查询在顶部获得“nite out”匹配结果,其余“nite”和“out”结果也在“nite out”匹配结果下方。
我将假设您的数据已经被索引nite,out并且nite out是匹配任何文档的标记。
其中一种方法是使用Match Query。Match 查询使用分析器来获取fuzziness您要查找的内容。在这种特定情况下,我们可以使用空白分析器来获得您正在寻找的结果。它将查看查询nite out并将其拆分为niteand out。然后匹配查询将搜索这两个标记,并根据相关性进行评分。一个同时nite out分析nite的文档将比仅分析或单独分析的文档out具有更高的分数。niteout
这是一个使用动态映射的三文档示例:
索引我们的文档:
PUI {"value":"out"}
PUT {"value":"nite"}
PUT {"value":"nite out"}
现在构造查询:
GET _search
{
"query": {
"match": {
"value": {
"query": "nite out",
"analyzer": "whitespace"
}
}
}
}
我们实际上不需要在这里指定空白分析器,实际上我们可以完全删除该行(和前面的逗号)。匹配查询将在我们在索引时查询的字段使用的分析器上运行查询文本。在我们的例子中,它是标准分析器,它将文本分成nite和out。
结果:
"hits": [
{
"_index": "test",
"_type": "test",
"_id": "1",
"_score": 0.2712221,
"_source": {
"value": "nite out"
}
},
{
"_index": "test",
"_type": "test",
"_id": "2",
"_score": 0.04500804,
"_source": {
"value": "nite"
}
},
{
"_index": "test",
"_type": "test",
"_id": "3",
"_score": 0.04500804,
"_source": {
"value": "out"
}
}
]
我鼓励您在此处阅读此链接,以了解 elasticsearch 中的不同搜索机制