ElastaticSearch -- es深度分页 searchAfter

searchAfter深度分页

es一次只能查1万条数据,如果超过1万,会报错如下:

复制代码
        "reason": {
          "type": "query_phase_execution_exception",
          "reason": "Result window is too large, from + size must be less than or equal to: [10000] but was [10001]. See the scroll api for a more efficient way to request large data sets. This limit can be set by changing the [index.max_result_window] index level setting."
        }

可以调整es配置的index.max_result_window这个参数,来查询更多的数据,但这并不是很好的办法,最好使用 searchAfter.

searchAfter作用类似于以下sql语句:

复制代码
-- 查询第10001--10005条数据
SELECT * FROM  t_user  order by name,birthDay  LIMIT 10000,5;

dsl

  • 第一次查询,查询1--10000条数据,找出第10000条数据的排序字段结果

    GET /user_info/_search
    {
    "size": 10000,
    "sort": [{
    "name": {
    "order": "asc"
    }
    },
    {
    "birthDay": {
    "order": "desc"
    }
    }]
    }

  • 第二次查询,根据上面最后一条数据的排序字段,查询出第 10001--20000条数据;
    多了一个search_after的查询条件,对应的排序字段为第一步查出来的最后一条数据(也就是第10000条数据)的排序字段

    GET /user_info/_search
    {
    "size": 10000,
    "sort": [{
    "name": {
    "order": "asc"
    }
    },
    {
    "birthDay": {
    "order": "desc"
    }
    }],
    "search_after": ["wang", "1993-12-01"]
    }

java代码

复制代码
    public SearchSourceBuilder searchAfterTest() {
        SearchSourceBuilder searc = new SearchSourceBuilder().size(10000);

        BoolQueryBuilder boolQuery = QueryBuilders.boolQuery();
//        boolQuery.filter(QueryBuilders.termQuery("province", "深圳市"));

        searc.sort("name", SortOrder.ASC).sort("birthDay", SortOrder.DESC);

        String[] searchAfter = new String[]{"wang", "1993-12-01"};
        searc.searchAfter(searchAfter);

        return searc.query(boolQuery);
    }
相关推荐
米饭不加菜5 分钟前
Git 从入门到精通:系统性的学习与实践指南
大数据·elasticsearch·搜索引擎
liu_sir_1 小时前
安卓设置界面-关于手机修改为关于设备
android·大数据·elasticsearch
Elasticsearch1 小时前
从平均值到任意百分位数:Elasticsearch 在 ES|QL 中原生支持指数直方图
elasticsearch
yulingfeng593 小时前
Elasticsearch 7.x 新手指南
大数据·elasticsearch·jenkins
jiayi_19993 小时前
[github] 上传本地repo
大数据·elasticsearch·github
逸Y 仙X4 小时前
文章二十八:ElasticSearch 运用指标聚合快速统计数值
java·大数据·elasticsearch·搜索引擎·全文检索
木易 士心4 小时前
一文彻底搞懂 Elasticsearch:原理、场景、避坑与优化
大数据·后端·elasticsearch·搜索引擎
小白编程锤炼5 小时前
深入解析:工程循环
大数据·elasticsearch·搜索引擎·vibe-coding
逸Y 仙X18 小时前
文章二十七:ElasticSearch ES查询模板(Search Template)高效复用实战
java·大数据·数据库·elasticsearch·搜索引擎·全文检索
AC赳赳老秦18 小时前
接口测试自动化:用 OpenClaw 对接 Postman,实现批量回归测试、测试报告自动生成与推送
java·人工智能·python·算法·elasticsearch·deepseek·openclaw