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

Posted 1994jinnan

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了springBoot集成es查询,使用ElasticsearchTemplate执行滚动查询相关的知识,希望对你有一定的参考价值。

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

直接上代码:

// 创建查询条件对象
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());

以上是关于springBoot集成es查询,使用ElasticsearchTemplate执行滚动查询的主要内容,如果未能解决你的问题,请参考以下文章

ElasticSearch_08_SpringBoot集成ES

ElasticSearch_07_SpringBoot集成ES

工作记录springboot集成spring-data-elasticsearch访问es及问题解决

ELK3.spring boot 2.X集成ES spring-data-ES 进行CRUD操作 完整版

Elastic Search 浅浅认识 快速使用 keyword 和 text 的区别之处 spring boot 集成案例 es 增删改查

应用接入ES-Springboot集成ES