欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 财经 > 金融 > ElasticSearch DSL查询之排序和分页

ElasticSearch DSL查询之排序和分页

2025/9/22 4:12:09 来源:https://blog.csdn.net/2301_80093566/article/details/145032922  浏览:    关键词:ElasticSearch DSL查询之排序和分页

一、排序功能

1. 默认排序

在 Elasticsearch 中,默认情况下,查询结果是根据 相关度 评分(score)进行排序的。我们之前已经了解过,相关度评分是通过 Elasticsearch 根据查询条件与文档内容的匹配程度自动计算得出的。如果不指定排序条件,Elasticsearch 会使用默认的相关度评分来排序查询结果。



2. 自定义排序

如果我们希望按照其他字段进行排序,而非使用默认的相关度排序(例如,按照价格、销量等字段),可以使用 sort 参数来指定排序字段。

排序字段的要求: 必须是数值类型、地理坐标或日期类型。

自定义排序的语法如下:

GET /indexName/_search
{"query": {"match_all": {}},"sort": [{"field": "asc"   // "排序字段":"排序方式" (asc:升序、desc:降序)}]
}
  • field:指定需要排序的字段名。asc(升序)或 desc(降序)。



3. 多字段排序

当需要根据多个字段进行排序时,我们可以在 sort 参数中指定多个字段。排序会根据数组中指定的顺序逐级进行:

  1. 首先按第一个字段排序。
  2. 如果第一个字段的值相同,则按第二个字段排序,以此类推。

例如,若我们需要先按销量排序,销量相同的情况下再按价格升序排序:



查询语句如下:

GET /items/_search
{"query": {"match_all": {}},"sort": [{"sold": "desc"  // 按销量降序排序},{"price": "asc"  // 销量相同,按价格升序排序}]
}

4. 排序结果说明

  • 排序后的查询结果不再根据相关度评分(_score)进行排序,因为我们已经指定了排序字段。
  • 结果中的 score 字段将为 null,因为排序不再依赖于相关度评分。
  • 查询结果将按照我们指定的排序字段进行排列。




二、分页功能

Elasticsearch 默认返回查询结果的前 10 条数据。如果我们希望查看更多数据,或者翻页查看查询结果,可以使用分页参数:fromsize

  • from:指定从第几条文档开始(类似于 SQL 中的 OFFSET)。
  • size:指定返回的文档数量(类似于 SQL 中的 LIMIT)。

分页的语法如下:

GET /items/_search
{"query": {"match_all": {}},"from": 0,   // 分页开始的位置,默认为0,从第 0 条开始"size": 10,   // 期望获取的文档总数,返回 10 条结果
}




三、分页与排序结合

在实际业务中,我们常常需要将分页和排序结合使用。

假设我们需要查询销量排名前 10 的商品,并且在销量相同的情况下按照价格升序排序。



查询语句:

GET /items/_search
{"query": {"match_all": {}},"sort": [{"sold": "desc"  // 按销量降序排序},{"price": "asc"  // 销量相同,按价格升序排序}],"from": 0,   // 从第 0 条开始"size": 10   // 返回 10 条结果
}

返回结果:




四、分页翻页

分页查询支持翻页功能。当我们查询第一页的结果时(from: 0, size: 10),若需要查看第二页的数据,可以将 from 设置为 10(即跳过前 10 条数据),然后返回接下来的 10 条数据:

GET /items/_search
{"query": {"match_all": {}},"sort": [{"sold": "desc"  // 按销量降序排序},{"price": "asc"  // 销量相同,按价格升序排序}],"from": 10,   // 跳过前 10 条数据,开始返回第 11 条"size": 10   // 返回 10 条结果
}




五、总结

  • 排序:通过 sort 参数指定排序字段,支持单字段排序和多字段排序。
  • 分页:通过 fromsize 参数控制返回数据的范围和条数。
  • 排序与分页结合:可以同时使用排序和分页功能,实现复杂的查询需求。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词