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

es滚动查询分析和使用步骤

ES在进行普通的查询时,默认只会查询出来10条数据。我们通过设置es中的size可以将最终的查询结果从10增加到10000。如果需要查询数据量大于es的翻页限制或者需要将es的数据进行导出又当如何?
Elasticsearch提供了一种称为"滚动查询"(Scrolling)的机制,用于处理大型数据集的分页查询。滚动查询允许在持续的时间段内保持一个活动的搜索上下文,然后使用滚动ID进行迭代检索结果。滚动查询和关系型数据库中的游标有点类似,因此也叫游标查询。

滚动查询的一般步骤

1、发起初始搜索请求,返回命中结果和滚动ID

scroll=5m表示每个滚动查询的有效时间为5分钟

下面例子:

POST /your_index/_search?scroll=5m
{"size": 100,       // 每次返回的结果数量"query": { ... }   // 查询条件
}

命中结果:

{"_scroll_id": "DXF1ZXJ5QW5kRmV0Y2gBAAAAAAAAAD4WYm9laVYtZndUQlNsdDcwakFMNjU1QQ==","hits": {"total": {"value": 10000,"relation": "eq"},"hits": [ ... ]  // 检索到的文档}
}

示例:
在这里插入图片描述

2、使用滚动查询下一页的结果:

例子:

POST /_search/scroll
{"scroll": "5m","scroll_id": "DXF1ZXJ5QW5kRmV0Y2gBAAAAAAAAAD4WYm9laVYtZndUQlNsdDcwakFMNjU1QQ=="
}

命中结果:
在这里插入图片描述

3、重复执行直到没有检索结果返回

Elasticsearch将返回下一页结果。可以根据需要重复这个步骤,直到没有更多结果为止,即无数据返回为止。

4、清除滚动上下文释放资源

滚动查询结束后,可以通过发送一个清除滚动上下文的请求来释放资源:

DELETE /_search/scroll
{"scroll_id": ["DXF1ZXJ5QW5kRmV0Y2gBAAAAAAAAAD4WYm9laVYtZndUQlNsdDcwakFMNjU1QQ=="]
}
http://www.lryc.cn/news/164372.html

相关文章:

  • 飞书公式总结
  • vue3.2 导出pdf文件或表格数据
  • Linux学习--MySQL学习之查询语句
  • 三、视频设备的枚举以及插拔检测
  • Qt开发_调用OpenCV(4.x)完成人脸检测并绘制马赛克(摄像头实时数据)
  • ssl证书有效期为什么越来越短?
  • XFF漏洞利用([SWPUCTF 2021 新赛]Do_you_know_http)
  • Java——》JVM对原生的锁做了哪些优化
  • 华为云云耀云服务器L实例评测|用docker搭建frp服务测试
  • 群狼调研(长沙满意度调查专业公司)开展公交车乘客满意度调查
  • Spring与OAuth2:实现第三方认证和授权的最佳实践
  • Mysql的定时备份与恢复
  • 学习Java基础面试题第五天
  • (10)(10.9) 术语表(一)
  • 面试(类加载器)
  • 二维差分---基础算法
  • C++之结构体智能指针shared_ptr实例(一百九十四)
  • 初出茅庐的小李博客之根据编译时间生成软件版本号
  • “投资教父”熊晓鸽老了,IDG光环不再
  • XEX智能交易所:加密货币衍生品杠杆、期货和期权简介
  • 记录第一次带后端团队
  • Python文件操作(02):读文件
  • Flink(java版)
  • 什么是动态组件以及使用场景
  • CRM销售管理系统如何提高销售效率
  • 纯小白安卓刷机1
  • C高级day4循环语句
  • Linux 操作系统云服务器安装部署 Tomcat 服务器详细教程
  • 【易盾点选】
  • vue中打印指定dom元素