19

我正在尝试按日期对多页结果中的搜索结果进行排序。排序在每个页面内都有效,有没有办法对整个集合进行排序?

例如:如果第 1 页包含从 2 月 13 日到 2 月 1 日的项目;第二页不应该有 2 月 1 日之后的项目。

这是我发送的请求的简短片段。我也尝试过按日期排序,然后按 _score 排序,但这会产生更奇怪的结果(主要是排序顺序是相同的)。

{
  "query": {
    "from": 0,
    "size": 24
    "sort": [
      "published_on": {
        "missing": "_last",
        "ignore_unmapped": true,
        "order": "desc"
      }
    ]
    "custom_filters_score": {
      "query": {
        "bool": {
          "must": [
            {
              "match": {
                "content": "Some query"
              }
            }
          ]
          ... more ...
        }
      },
      "filters": [
        {
          "filter" => {
            "type" => {
              "value" => "cats"
            }
          },
          "boost" => 2
        }
        ... more ...
      ]
    }
  }
}

有什么想法吗?提前致谢!

4

2 回答 2

20

我没有将页面索引乘以页面上的项目数。我不确定我是如何在每一页上错过了相同的整体,向上移动了一个点。

我相信这将解决我一直在处理的所有其他奇怪问题。

于 2013-02-15T16:36:03.123 回答
8

sort, size, from 必须在根目录

    {
       query:{
          ...
       },
       sort:[
         ...
       ],
       from:15,
       size:5
    }

搜索 API - 排序

于 2013-02-15T13:02:15.247 回答