java获取elasticsearch所有的数据

编程知识 行业动态 更新时间:2024-06-13 00:21:18

 

注意:下面的代码是用的java-high客户端

在贴出程序之前先提出几个问题,首先在搜索引擎中任何时候涉及到批量数据处理的时候,都不可能在一次请求中获取到所有的数据,这样是为了节省内存,而且全部拿到也不现实,一般都是分页获取的,也就是说先给你展示,下一页的话通过你的点击会从上次展示的位置往后获取数据,而这个位置你可以理解为位置指针。就这样循环获取循环请求才能真正的将数据全部拿到。下面的程序我没有做整理,不过认真看的话,你呢个get到你的点。

 public static void ScroolSearchID(String sourceIndex,String desIndex) {
        try {
            SearchRequest searchRequest = new SearchRequest(sourceIndex);
            //请求设置
            SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
            searchSourceBuilder.query(QueryBuilders.matchAllQuery());
            searchSourceBuilder.fetchSource(false);
            searchSourceBuilder.size(1000);
            searchRequest.scroll(TimeValue.timeValueMinutes(5L));
            searchRequest.source(searchSourceBuilder);
//            请求发送
            SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT);
            SearchHit[] searchHit = searchResponse.getHits().getHits();
            int i = 1;
            while ((searchHit != null && searchHit.length > 0)) {
                try {
               //自定义处理查询结果代码  searchHit 就是查询结果
                  
                } catch (Exception e) {
                    e.printStackTrace();
                }

//        重置searchResponse 和ID
                String scrollId = searchResponse.getScrollId();
                SearchScrollRequest scrollRequest = new SearchScrollRequest(scrollId);
                scrollRequest.scroll(TimeValue.timeValueMinutes(5));
                searchResponse = client.scroll(scrollRequest, RequestOptions.DEFAULT);
                searchHit = searchResponse.getHits().getHits();
                i++;
            }

        } catch (IOException e) {
            e.printStackTrace();
        }


    }

 

更多推荐

java获取elasticsearch所有的数据

本文发布于:2023-03-31 14:15:00,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/a2441f94a79425c81eac930daa44ff96.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:数据   java   elasticsearch

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!