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

版本: 6.8-8.9

简而言之,当 Elasticsearch 中的 ‘span_within’ 查询格式不正确时,会出现此错误。‘span_within’ 查询需要 ‘span’ 类型的查询,但提供的查询似乎不是此类型。要解决此问题,你应该确保 ‘span_within’ 中的查询是有效的 ‘span’ 类型查询。这可能涉及检查查询的语法和结构,确保它符合 ‘span’ 查询的所需格式。此外,确保你查询的字段支持此类型的查询。

日志上下文 #

日志 “span_within [big] must be of type span query” 类名是 SpanWithinQueryBuilder.java。 我们从 Elasticsearch 源代码中提取了以下内容,供那些寻求深入了解上下文的人使用:

currentFieldName = parser.currentName();
 } else if (token == XContentParser.Token.START_OBJECT) {
 if (BIG_FIELD.match(currentFieldName; parser.getDeprecationHandler())) {
 QueryBuilder query = parseInnerQueryBuilder(parser);
 if (query instanceof SpanQueryBuilder == false) {
 throw new ParsingException(parser.getTokenLocation(); "span_within [big] must be of type span query");
 }
 big = (SpanQueryBuilder) query;
 checkNoBoost(NAME; currentFieldName; parser; big);
 } else if (LITTLE_FIELD.match(currentFieldName; parser.getDeprecationHandler())) {
 QueryBuilder query = parseInnerQueryBuilder(parser);