elasticsearch - 在 'function_score' 内获得中间分数

elasticsearch - get intermediate scores within 'function_score'

这是我的索引

POST /blogs/1
{
  "name" : "learn java", 
  "popularity" : 100
}

POST /blogs/2
{
  "name" : "learn elasticsearch", 
  "popularity" : 10
}

我的搜索查询:

GET /blogs/_search
{
  "query": {
    "function_score": {
      "query": {
        "match": {
          "name": "learn"
        }
      },
      "script_score": {
        "script": {
          "source": "_score*(1+Math.log(1+doc['popularity'].value))"
        }
      }
    }
  }
}

其中 return 个:

[
  {
    "_index": "blogs",
    "_type": "1",
    "_id": "AW5fxnperVbDy5wjSDBC",
    "_score": 0.58024323,
    "_source": {
      "name": "learn elastic search",
      "popularity": 100
    }
  },
  {
    "_index": "blogs",
    "_type": "1",
    "_id": "AW5fxqmL8cCMCxtBYOyC",
    "_score": 0.43638366,
    "_source": {
      "name": "learn java",
      "popularity": 10
    }
  }
]

问题:我需要在结果中 return 一个额外的字段,这将给我原始分数(只是 tf/idf,不考虑受欢迎程度)

我探索过的事情:script_fields(在获取时无法访问 _score

问题出在您查询的方式上,它覆盖了 _score 变量。相反,如果您使用 sort,则 _score 不会更改,并且可以在同一查询中提取。

您可以试试这样查询:

{
  "query": {
    "match": {
      "name": "learn"
    }
  },
  "sort": [
    {
      "_script": {
        "type": "number",
        "script": {
          "lang": "painless",
          "source": "_score*(1+Math.log(1+doc['popularity'].value))"
        },
        "order": "desc"
      }
    },
    "_score"
  ]
}