一、背景
我们在查看列表数据时通常需要对列表数据进行排序。es默认按照分数进行排序,我们使用我们自己业务表中的字段排序时,发现原先排序的分数为null。但是我们又想要展示原本的分数值,该如何解决呢?
二、原因
当我们在使用sort参数对查询结果进行排序时,Elasticsearch会忽略查询的评分,并基于你指定的排序字段来重新排序结果。这意味着_score字段将不再反映查询的相关性,而是基于排序字段的值。
三、解决方案
- 我发现在搜索中实际分数时计算的只是在hit中没有赋值
GET /你的索引/_search?explain=true
添加以下代码,获取计算的分数值
// 创建解释请求
ExplainRequest explainRequest = new ExplainRequest();
explainRequest.index(hit.getIndex());
explainRequest.type(hit.getType());
explainRequest.id(hit.getId());
explainRequest.explain(sourceBuilder.query()); // 使用相同的查询条件
// 获取解释响应
ExplainResponse explainResponse = client.explain(explainRequest, RequestOptions.DEFAULT);
// 输出解释信息
System.out.println(explainResponse.getExplanation());