--- title: "我们只支持基于数字字段的AVG、MEDIAN和SUM" date: 2026-01-06 lastmod: 2026-01-06 description: "在非数值字段上执行AVG、MEDIAN或SUM操作导致的错误及解决方案" tags: ["Elasticsearch", "聚合", "数值字段", "排序"] summary: " 版本: 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) { " --- > **版本:** 6.8-8.9 简而言之,当您尝试在Elasticsearch中的非数值字段上执行AVG、MEDIAN或SUM操作时,就会出现此错误。这些操作仅支持数值字段。要解决此问题,请确保您尝试操作的字段是数值类型。如果不是,您可能需要使用正确的映射重新索引数据,或在执行这些操作之前使用脚本将字段转换为数值类型。 ## 日志上下文 日志"we only support AVG, MEDIAN and SUM on number based fields"的类名是[FieldSortBuilder.java](https://www.geeksforgeeks.org/java-lang-class-class-java-set-1/)。我们从Elasticsearch源代码中提取了以下内容,供那些寻求深入上下文的人使用: ```java } 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) { ```