elasticsearch query里面的slop选项

时间:2022-07-25
本文章向大家介绍elasticsearch query里面的slop选项,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

slop

用过搜索引擎的都知道,输入一个query,然后会出很多联想的词条,如下面:

一般来说完全精确短语匹配 或许是过于严格了。 也许我们想要包含 “quick brown fox” 的词条也能够匹配 “quick fox,” , 尽管情形不完全相同。

我们能够通过使用 slop 参数将灵活度引入短语匹配中。

slop 参数告诉 match_phrase 查询词条相隔多远时仍然能将文档视为匹配 。 相隔多远的意思是为了让查询和文档匹配你需要移动词条多少次?

我们以一个简单的例子开始吧。 为了让查询 quick fox 能匹配一个包含 quick brown fox 的文档, 我们需要 slop 的值为 1:

GET /my_index/my_type/_search
{
    "query": {
        "match_phrase": {
            "title": {
            	"query": "quick fox",
            	"slop":  1
            }
        }
    }
}

尽管在使用了 slop 短语匹配中所有的单词都需要出现, 但是这些单词也不必为了匹配而按相同的序列排列。 有了足够大的 slop 值, 单词就能按照任意顺序排列了。

为了使查询 fox quick 匹配我们的quick brown fox词条, 我们需要 slop 的值为 3: 其实也就是,转化顺序一次,然后相隔两次。slop = 1 + 2;

就是说 slop 在 相隔一个term词算一次,或者在顺序转化也算一次。