ElastichSearchelasticsearch玩转大数据

九、Elasticsearch基于boost的细粒度搜索条件权重

2017-07-15  本文已影响93人  编程界的小学生

需求:搜索标题中包含blog的帖子,同时,如果标题包含Hadoop或java或spark或Elasticsearch,就优先输出包含java的,在输出spark的,在输出Hadoop的,最后输出Elasticsearch的。

GET /forum/article/_search
{
  "query": {
    "bool": {
      "must": [
        {
          "term" : {"title" : "blog"}
        }
      ],
      "should": [
        {
          "term": {
            "title": {
              "value": "java",
              "boost": 5
            }
          }
        },
        {
          "term": {
            "title": {
              "value": "spark",
              "boost": 4
            }
          }
        },
        {
          "term": {
            "title": {
              "value": "hadoop",
              "boost": 3
            }
          }
        },
        {
          "term": {
            "title": {
              "value": "elasticsearch"
            }
          }
        }
      ]
    }
  }
}

知识点:搜索条件的权重,boost,可以将某个搜索条件的权重加大,此时当匹配这个搜索条件和匹配另一个搜索条件的document,计算relevance score时,匹配权重更大的搜索条件的document,relevance score会更高,当然也就会优先被返回回来。
默认情况下,搜索条件的权重都是1

若有兴趣,欢迎来加入群,【Java初学者学习交流群】:458430385,此群有Java开发人员、UI设计人员和前端工程师。有问必答,共同探讨学习,一起进步!
欢迎关注我的微信公众号【Java码农社区】,会定时推送各种干货:


qrcode_for_gh_577b64e73701_258.jpg
上一篇下一篇

猜你喜欢

热点阅读