在做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了。
本文来自博客园,作者:|旧市拾荒|,转载请注明原文链接:https://www.cnblogs.com/xiaoyh/p/15574706.html
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之家整理,本文链接:https://www.bmabk.com/index.php/post/13425.html