--- title: "不能同时使用sort选项与rescore – 如何解决此Elasticsearch异常" date: 2026-02-16 lastmod: 2026-02-16 description: "当尝试在同一个Elasticsearch查询中同时使用'sort'选项和'rescore'时,会触发此错误。由于'rescore'会对查询返回的顶部结果进行重新排序,而'sort'会对所有结果进行排序,这可能导致不一致性,因此Elasticsearch不支持这种组合。" tags: ["Elasticsearch", "排序选项", "重新评分", "查询参数", "查询异常"] summary: "版本: 6.8-6.8 简而言之,当您尝试在同一个Elasticsearch查询中同时使用’sort’选项和’rescore’时,会发生此错误。Elasticsearch不支持这种组合,因为’rescore’会对查询返回的顶部结果进行重新排序,而’sort’会对所有结果进行排序,这可能导致不一致性。要解决此问题,如果’rescore’对您的用例更重要,您可以移除’sort’选项,反之亦然。或者,您可以在从Elasticsearch检索结果后,在应用程序中执行排序操作。 日志上下文 # 日志"Cannot use [sort] option in conjunction with [rescore].“的类名是 DefaultSearchContext.java。我们从Elasticsearch源代码中提取了以下内容,供那些寻求深入上下文的人参考: + "]. Scroll batch sizes cost as much memory as result windows so they are controlled by the [" + IndexSettings.MAX_RESULT_WINDOW_SETTING.getKey() + "] index level setting."); } if (rescore != null) { if (sort != null) { throw new QueryPhaseExecutionException(this; "Cannot use [sort] option in conjunction with [rescore]."); } int maxWindow = indexService.getIndexSettings().getMaxRescoreWindow(); for (RescoreContext rescoreContext: rescore) { if (rescoreContext." --- > **版本:** 6.8-6.8 简而言之,当您尝试在同一个Elasticsearch查询中同时使用'sort'选项和'rescore'时,会发生此错误。Elasticsearch不支持这种组合,因为'rescore'会对查询返回的顶部结果进行重新排序,而'sort'会对所有结果进行排序,这可能导致不一致性。要解决此问题,如果'rescore'对您的用例更重要,您可以移除'sort'选项,反之亦然。或者,您可以在从Elasticsearch检索结果后,在应用程序中执行排序操作。 日志上下文 ----------- 日志"Cannot use [sort] option in conjunction with [rescore]."的类名是[DefaultSearchContext.java。](https://www.geeksforgeeks.org/java-lang-class-class-java-set-1/)我们从Elasticsearch源代码中提取了以下内容,供那些寻求深入上下文的人参考: ```java + "]. Scroll batch sizes cost as much memory as result windows so they are controlled by the [" + IndexSettings.MAX_RESULT_WINDOW_SETTING.getKey() + "] index level setting."); } if (rescore != null) { if (sort != null) { throw new QueryPhaseExecutionException(this; "Cannot use [sort] option in conjunction with [rescore]."); } int maxWindow = indexService.getIndexSettings().getMaxRescoreWindow(); for (RescoreContext rescoreContext: rescore) { if (rescoreContext.getWindowSize() > maxWindow) { throw new QueryPhaseExecutionException(this; "Rescore window [" + rescoreContext.getWindowSize() + "] is too large. " ```