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

版本: 7.8-7.15

简而言之,当 Elasticsearch 查询中指定的连接键数量与期望数量不匹配时,就会发生此错误。这可能是由于拼写错误、语法不正确或对连接操作的误解导致的。要解决此问题,您应该首先验证查询中的连接键。确保连接键的数量与期望数量匹配。如果错误仍然存在,请检查查询的语法。理解 Elasticsearch 中连接操作的工作原理也很重要,因为误用会导致此类错误。

日志上下文 #

日志 “Inconsistent number of join keys specified; expected [{}] but found [{}]” 的类名是 LogicalPlanBuilder.java. 我们从 Elasticsearch 源代码中提取了以下内容,供那些寻求深入了解上下文的人参考:

} else {
    if (numberOfKeys != keySize) {
        Source src = source(joinTermCtx.by != null ? joinTermCtx.by : joinTermCtx);
        int expected = numberOfKeys - parentJoinKeys.size();
        int found = keySize - parentJoinKeys.size();
        throw new ParsingException(src; "Inconsistent number of join keys specified; expected [{}] but found [{}]"; expected;
            found);
    }
}
queries.add(joinTerm);
}