将自定义分数分配给 Elasticsearch 中布尔查询中的子句

问题描述

在 Elasticsearch 中,我正在测试以下查询:

GET sdata/_search
{
  "query": {
    "bool": {
      "must": [
        { "match": { "f1": "sth" } }
      ],"should": [
        { "match": { "f2": "sth" } }
      ]
    }
  }
}

我知道检索到的文档的总分取决于它们实现的匹配数。但是是否可以自定义最终分数,以便匹配 should 子句的文档的权重可能比单独匹配 must 的文档高得多?我可以添加一个脚本来确定每个子句对最终分数的影响吗?

提前致谢

解决方法

您可以将 boost 参数与 should 子句一起使用

{
  "query": {
    "bool": {
      "must": [
        {
          "match": {
            "f1": "sth"
          }
        }
      ],"should": [
        {
          "match": {
            "f2": {
              "query": "sth","boost": 10
            }
          }
        }
      ]
    }
  }
}

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...