查询全部
@SpringBootTestpublic class MyTest{    //注入RestHighLevelClient对象    @Autowired    private RestHighLevelClient restHighLevelClient;    @Test    public void test() throws IOException {        //准备SearchRequest请求对象,并指定索引库名        SearchRequest searchRequest = new SearchRequest(索引库名);        //准备MatchAllQueryBuilder查询对象        MatchAllQueryBuilder matchAllQueryBuilder = QueryBuilders.matchAllQuery();        //在SearchRequest请求对象中放入MatchAllQueryBuilder查询对象        searchRequest.source().query(matchAllQueryBuilder);        //发送请求,得到响应对象        SearchResponse searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);        //从响应对象中获取响应结果        SearchHits searchHits = searchResponse.getHits();        //获取文档的总条数        long total = searchHits.getTotalHits().value;        //获取搜索结果数组        SearchHit[] hits = searchHits.getHits();        //创建文档集合,用于存放结果        List<文档类名> 集合对象名 = new ArrayList<>();        //遍历数组        for (SearchHit hit : hits) {            //获取Json格式的文档内容            String json = hit.getSourceAsString();            //反序列化Json,这里需要引入fastjson的依赖            文档类名 文档对象名 = JSON.parseObject(json, 文档类名.class);            //将结果放入集合            集合对象名.add(文档对象名);        }    }}
单字段查询
@SpringBootTestpublic class MyTest{    //注入RestHighLevelClient对象    @Autowired    private RestHighLevelClient restHighLevelClient;    @Test    public void test() throws IOException {        //准备SearchRequest请求对象,并指定索引库名        SearchRequest searchRequest = new SearchRequest(索引库名);        //准备MatchQueryBuilder查询对象,并指定查询字段和查询数据        MatchQueryBuilder matchQueryBuilder = QueryBuilders.matchQuery(字段名, 搜索词);        //在SearchRequest请求对象中放入MatchQueryBuilder查询对象        searchRequest.source().query(matchQueryBuilder);        //发送请求,得到响应对象        SearchResponse searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);        //从响应对象中获取响应结果        SearchHits searchHits = searchResponse.getHits();        //获取文档的总条数        long total = searchHits.getTotalHits().value;        //获取搜索结果数组        SearchHit[] hits = searchHits.getHits();        //创建文档集合,用于存放结果        List<文档类名> 集合对象名 = new ArrayList<>();        //遍历数组        for (SearchHit hit : hits) {            //获取Json格式的文档内容            String json = hit.getSourceAsString();            //反序列化Json,这里需要引入fastjson的依赖            文档类名 文档对象名 = JSON.parseObject(json, 文档类名.class);            //将结果放入集合            集合对象名.add(文档对象名);        }    }}
多字段查询
@SpringBootTestpublic class MyTest{    //注入RestHighLevelClient对象    @Autowired    private RestHighLevelClient restHighLevelClient;    @Test    public void test() throws IOException {        //准备SearchRequest请求对象,并指定索引库名        SearchRequest searchRequest = new SearchRequest(索引库名);        //准备MultiMatchQueryBuilder查询对象,并指定查询数据和多个查询字段        MultiMatchQueryBuilder multiMatchQueryBuilder = QueryBuilders.multiMatchQuery(搜索词, 字段名1, 字段名2 , ...);        //在SearchRequest请求对象中放入MultiMatchQueryBuilder查询对象        searchRequest.source().query(multiMatchQueryBuilder);        //发送请求,得到响应对象        SearchResponse searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);        //从响应对象中获取响应结果        SearchHits searchHits = searchResponse.getHits();        //获取文档的总条数        long total = searchHits.getTotalHits().value;        //获取搜索结果数组        SearchHit[] hits = searchHits.getHits();        //创建文档集合,用于存放结果        List<文档类名> 集合对象名 = new ArrayList<>();        //遍历数组        for (SearchHit hit : hits) {            //获取Json格式的文档内容            String json = hit.getSourceAsString();            //反序列化Json,这里需要引入fastjson的依赖            文档类名 文档对象名 = JSON.parseObject(json, 文档类名.class);            //将结果放入集合            集合对象名.add(文档对象名);        }    }}