elasticsearch学习笔记高级篇(八)——基于boost的细粒度搜索条件权重控制

需求:搜索标题中包含java的帖子,同时若是标题中包含hadoop和elasticsearch就优先搜索出来,同时,若是一个帖子包含java hadoop,一个帖子包含java elasticsearch,包含hadoop的帖子要比elasticsearch优先搜索出来。java

搜索条件的权重,boost,能够将某个搜索条件的权重加大,此时当匹配这个搜索条件和匹配另外一个搜索条件的document,计算relevance score时,匹配权重更大的搜索条件的document, relevance score会更高,固然也就会优先被返回回来。elasticsearch

在默认的状况下,搜索条件的权重都是同样的,都是1oop

GET /forum/_search
{
  "query": {
    "bool": {
      "must": [
        {
          "match": {
            "title": "java"
          }
        }
      ],
      "should": [
        {
          "match": {
            "title": "hadoop"
          }
        },
        {
          "match": {
            "title": "elasticsearch"
          }
        },
        {
          "match": {
            "title": "spark"
          }
        }
      ]
    }
  }
}

这个测试很差复现,在出现的结果中若是不是咱们想要的,咱们能够根据上面的需求调节一下boost,来让最后的返回结果达到咱们的预期。测试

GET /forum/_search
{
  "query": {
    "bool": {
      "must": [
        {
          "match": {
            "title": "java"
          }
        }
      ],
      "should": [
        {
          "match": {
            "title": {
              "query": "hadoop",
              "boost": 5
            }
          }
        },
        {
          "match": {
            "title": {
              "query": "elasticsearch",
              "boost": 3
            }
          }
        },
        {
          "match": {
            "title": {
              "query": "spark",
              "boost": 1
            }
          }
        }
      ]
    }
  }
}
相关文章
相关标签/搜索