📣 极限科技诚招搜索运维工程师(Elasticsearch/Easysearch)- 全职/北京 👉 : 立即申请加入

版本: 6.8-8.9

简而言之,当您尝试在Elasticsearch中的非数值字段上执行AVG、MEDIAN或SUM操作时,就会出现此错误。这些操作仅支持数值字段。要解决此问题,请确保您尝试操作的字段是数值类型。如果不是,您可能需要使用正确的映射重新索引数据,或在执行这些操作之前使用脚本将字段转换为数值类型。

日志上下文 #

日志"we only support AVG, MEDIAN and SUM on number based fields"的类名是 FieldSortBuilder.java。我们从Elasticsearch源代码中提取了以下内容,供那些寻求深入上下文的人使用:

}  IndexFieldDatafieldData = context.getForField(fieldType, MappedFieldType.FielddataOperation.SEARCH);
 if (fieldData instanceof IndexNumericFieldData == false
 && (sortMode == SortMode.SUM || sortMode == SortMode.AVG || sortMode == SortMode.MEDIAN)) {
 throw new QueryShardException(context, "we only support AVG, MEDIAN and SUM on number based fields");
 }
 final SortField field;
 boolean isNanosecond = false;
 if (numericType != null) {
 if (fieldData instanceof IndexNumericFieldData == false) {