elasticsearch-多词短语无序查询

来源:互联网 发布:qq三国转职js技能 编辑:程序博客网 时间:2024/06/05 19:26

混合起来

精确短语匹配 或许是过于严格了。也许我们想要包含 quick brown fox'' 的文档也能够匹配 quick fox,'' , 尽管情形不完全相同。

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

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

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

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

            Pos 1         Pos 2         Pos 3-----------------------------------------------Doc:        quick         brown         fox-----------------------------------------------Query:      quick         foxSlop 1:     quick                 ↳     fox

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

为了使查询 fox quick 匹配我们的文档, 我们需要 slop 的值为 3:

            Pos 1         Pos 2         Pos 3-----------------------------------------------Doc:        quick         brown         fox-----------------------------------------------Query:      fox           quickSlop 1:     fox|quick  ↵  (1)Slop 2:     quick      ↳  foxSlop 3:     quick                 ↳     fox
  1. 注意 fox 和 quick 在这步中占据同样的位置。 因此将 fox quick 转换顺序成 quick fox 需要两步, 或者值为 2 的 slop 。


0 0
原创粉丝点击