当前位置: 首页 > article >正文

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 参数控制返回数据的范围和条数。
  • 排序与分页结合:可以同时使用排序和分页功能,实现复杂的查询需求。

http://www.kler.cn/a/513999.html

相关文章:

  • CSS中相对定位和绝对定位详解
  • 常见Arthas命令与实践
  • Qt中的connect函数
  • 解决后端接口返回Long类型参数导致的精度丢失问题
  • 为什么你的 Qt 应用程序会出现 xcb 插件错误
  • C++经典例题
  • AWTK-WEB 快速入门(3) - C 语言 Http 应用程序
  • Transformer的编码机制
  • 基于Python机器学习的双色球数据分析与预测
  • U-Net - U型网络:用于图像分割的卷积神经网络
  • linux环境变量配置文件区别 /etc/profile和~/.bash_profile
  • 高频次UDP 小包丢包分析
  • 项目集成ELK
  • 【腾讯云】docker创建网络遇到Unable to enable SKIP DNAT rule
  • wordpress付费查看隐藏内容插件的开发演示和记录
  • 【系统架构】如何设计一个秒杀系统?
  • Java学习,List截取
  • 解锁速度之门:Redis
  • 《C++ primer plus》第六版课后编程题-第05章
  • root用户Linux银河麒麟服务器安装vnc服务
  • Java设计模式 六 原型模式 (Prototype Pattern)
  • TRELLIS微软的图生3D
  • 基于 MDL 行情插件的中金所 L1 数据处理最佳实践
  • 【Linux】多线程(二)
  • Linux:常用命令--文件与目录操作
  • docker构建Java项目镜像常用的Java版本,国内私有仓库公网快速下载,解决从docker.io无法下载的问题