发布于 

springBoot集成es使用ElasticsearchTemplate执行滚动查询

使用Elasticsearch查询大量数据时基本的分页查询就会报错,这种情况下可以使用scroll(滚动)查询

直接上代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
// 创建查询条件对象
BoolQueryBuilder queryBuilder = QueryBuilders.boolQuery();

// 拼接查询条件
queryBuilder.must(QueryBuilders.termQuery("status", 1)); 假设查询状态为1

// 创建查询对象
SearchQuery searchQuery = new NativeSearchQueryBuilder()
.withIndices("test_index")//索引名
.withTypes("test")//类型名
.withQuery(queryBuilder)// 查询条件对象
.withPageable(PageRequest.of(0, 1000))//从0页开始查,每页1000个结果
.build();

// 滚动查询
ScrolledPage<TestEntity> scroll = (ScrolledPage<TestEntity>) elasticsearchTemplate.startScroll(3000, searchQuery, TestEntity.class);

// 判断是否有内容
while (scroll.hasContent()) {
List<TestEntity> content = scroll.getContent();
// 业务逻辑省略
//取下一页,scrollId在es服务器上可能会发生变化,需要用最新的。发起continueScroll请求会重新刷新快照保留时间
scroll = (ScrolledPage<TestEntity>) elasticsearchTemplate.continueScroll(scroll.getScrollId(), 3000, EstateInfoEntity.class);
}

// 最后释放查询
elasticsearchTemplate.clearScroll(scroll.getScrollId());

本站由 @binvv 使用 Stellar 主题创建。
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议,转载请注明出处。