设置参数 `node.name` 可以自定义 Elasticsearch 节点的名字。 此条 Tips 由 medcl 贡献。

ES打分问题请教

Elasticsearch | 作者 elisha | 发布于2018年03月09日 | 阅读数:2550

查询语句如下,有三个查询字段(corp_name、former_name、stockname),现有的打分策略是把三个匹配字段的得分结果相加,比如搜索"北京"时,如果一个doc中三个字段都包含北京,则最终该doc的得分是三个分值相加,有没有办法实现doc得分取三个字段中最高的得分{
  "sort": [
    {
      "_score": {
        "order": "desc"
      }
    }
  ], 
  "from": "0",
  "size": "15"
  "query": {
    "bool": {
      "must": [
        {
          "multi_match": {
            "fields": [
              "corp_name",           
              "former_name",           
              "stockname"
            ],
            "operator": "and",
            "query": "北京",
            "type": "phrase",
            "slop": 20
          }
        }
      ]
    }
  },
  
}
已邀请:

elisha - 80后 IT

赞同来自:

ES里面有个function_score,貌似也不是很好用
 

rockybean - Elastic Certified Engineer, ElasticStack Fans,公众号:ElasticTalk

赞同来自:

可以试试 dis max query
https://www.elastic.co/guide/e ... .html

chennanfei - 吹风

赞同来自:

用MultiMatch 的 BestFields模式。

要回复问题请先登录注册