错误解决:ElasticSearch SearchResponse的Hits[]总是比totalHits少一条记录
2023-03-14 09:43:52 时间
在做ElasticSearch查询操作的时候,发现Hits[].length总是比totalHits.value少1。
代码如下:
SearchRequest request = new SearchRequest("indexName"); SearchSourceBuilder builder = new SearchSourceBuilder(); BoolQueryBuilder boolQueryBuilder = new BoolQueryBuilder(); builder.query(QueryBuilder.matchPhraseQuery("fieldName","searchStr")); builder.from(1); builder.size(10); request.source(builder); SearchResponse response = restHighLevelClient.search(request,RequestOptions.DEFAULT); // 获取查询总数 System.out.println(response.getHits().getTotalHits().value); // 获取查询分页数量 System.out.println(response.getHits().getHits().length);
输出结果:
第二行总是比第一行少1。
按照常规分页的思想,其实应该是从第一页开始,然后跟上每页的数据,没想到这里from(1)直接把第一条数据给跳过了。
解决办法:
直接from(0)就ok了。
相关文章
- 七月数据库排行榜:MongoDB 和 Oracle 分数下降最多
- 数亿数据MySQL撑不住,无缝迁移到MongoDB后稳得一批!
- Kotlin、JUnit5、Database Rider数据库动态测试实践
- MySQL主键自增值为什么有“空洞”?
- 分库分表实战:寻根问底—MySQL索引是如何形成的?
- 分库分表实战:追根溯源—一次查询会经过哪些流程呢?
- 如何打造一个高性能的前端智能推理引擎
- MySQL数据库中查找最常用的数据类型
- Redis 的内存淘汰策略和过期删除策略,你别再搞混了!
- 横空出世的 Data Fabric,是下一个风口吗?
- 云数据建模:为数据仓库设计数据库
- Group By 有哪些注意事项?你知道吗?
- 字节云数据库未来方向的探索与实践
- 2022上半年盘点:20+主流数据库重大更新及技术要点汇总
- 流批一体在京东的探索与实践
- 谈谈你对NoSQL的理解
- SQL中常用的四个排序函数,你知道几个?
- Redisson 高性能 Redis 分布式锁源码分析
- 为什么MySQL的count()方法这么慢?
- 解决MySQL幻读的终极指南