您的位置:首页 > 健康 > 养生 > 使用 RestHighLevelClient 进行 Elasticsearch 分页查询

使用 RestHighLevelClient 进行 Elasticsearch 分页查询

2025/1/9 18:14:01 来源:https://blog.csdn.net/qq_29752857/article/details/141147236  浏览:    关键词:使用 RestHighLevelClient 进行 Elasticsearch 分页查询

在处理大量数据的搜索应用中,分页查询是一种常见的需求。Elasticsearch 以其灵活的搜索能力,支持高效的分页查询操作。本文将介绍如何在 Java 应用程序中使用 Elasticsearch 的 RestHighLevelClient 执行分页查询,并展示如何结合排序进行结果的有序展示。

环境准备

确保你的项目中已经添加了 Elasticsearch 客户端库的依赖。如果使用 Maven,可以在 pom.xml 文件中添加如下依赖:

<dependency><groupId>org.elasticsearch.client</groupId><artifactId>elasticsearch-rest-high-level</artifactId><version>7.10.0</version> <!-- 使用适合的版本号 -->
</dependency>

分页查询示例

1. 分页查询基础

在 Elasticsearch 中,可以通过设置 fromsize 参数来实现分页查询。

Java Code
@Test
void testPagination() throws IOException {// 页码,每页大小int page = 1, size = 5;// 1. 准备 SearchRequestSearchRequest request = new SearchRequest("hotel"); // 指定索引名称// 2. 准备 DSL 查询request.source().query(QueryBuilders.matchAllQuery()) // 查询所有文档.sort("price", SortOrder.ASC) // 按价格升序排序.from((page - 1) * size) // 分页开始位置.size(size); // 每页大小// 3. 发送请求SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 4. 解析响应handleResponse(response);
}
DSL Equivalent

在这里插入图片描述

GET /hotel/_search
{"query": {"match_all": {}},"sort": [{"price": {"order": "asc"}}],"from": 0,"size": 5
}

2. 响应处理

定义一个通用方法来处理搜索响应,打印结果。

private void handleResponse(SearchResponse response) throws IOException {SearchHits searchHits = response.getHits();long total = searchHits.getTotalHits().value;System.out.println("共搜索到 " + total + " 条数据");for (SearchHit hit : searchHits.getHits()) {String json = hit.getSourceAsString();System.out.println(json);}
}

结语

Elasticsearch 的分页查询功能通过简单的 API 调用即可实现,结合 fromsize 参数,我们可以轻松地对搜索结果进行分页处理。在实际应用中,分页查询可以显著提高用户体验和后端性能。本文提供的示例代码展示了如何使用 Java 的 RestHighLevelClient 进行分页查询,并给出了对应的 DSL 查询语句,帮助你更好地理解和使用 Elasticsearch 的分页功能。

版权声明:

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

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