美文网首页ElastichSearchelasticsearch玩转大数据
九、Elasticsearch基于boost的细粒度搜索条件权重

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

作者: 编程界的小学生 | 来源:发表于2017-07-15 14:02 被阅读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

    相关文章

      网友评论

        本文标题:九、Elasticsearch基于boost的细粒度搜索条件权重

        本文链接:https://www.haomeiwen.com/subject/zvnahxtx.html