es 使用 function_score 时报错 NaN

在使用Elasticsearch的function_score查询时遇到500错误,提示某个文档(doc:866)的分数计算结果为NaN。为定位问题,建议在function_score的source中设置条件,当计算得分出现NaN时,赋予一个极大值如999999999,使出错的文档在结果中突出显示。通过这种方式,可以逐步检查和修复用户自定义的评分函数,确保所有计算都是有效的。
摘要由CSDN通过智能技术生成

使用 function_score 自定义评分时,进行搜索,提示如下错误

elasticsearch.exceptions.TransportError: TransportError(500, 'search_phase_execution_exception', 'function score query returned an invalid score: NaN for doc: 866')

显然,这个 866 不是 es 的_id 字段,那么怎么找到出错的数据呢?
方案:在 function_score 的 source 字段进行判断:如果是 NaN ,则手动赋值分数为 999999999,有问题的这条 document 会返回在结果中的第一个。
据此逐一排查用户计算的字段,代码实现:

if (Double.isNaN(myscore)) {
    return 999999999;
}
return myscore;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值