• ES入门 (13)Java API 操作(4)DQL(1) 请求体查询/term 查询,查询条件为关键字/分页查询/数据排序/过滤字段/Bool 查询/范围查询/模糊查询/高亮查询/聚合查询/分组查询


    1 请求体查询

    2 高亮查询

    3 聚合查询

    package com.atguigu.es.test;
    
    import org.apache.http.HttpHost;
    import org.apache.lucene.search.TotalHits;
    import org.elasticsearch.action.get.GetRequest;
    import org.elasticsearch.action.get.GetResponse;
    import org.elasticsearch.action.search.SearchRequest;
    import org.elasticsearch.action.search.SearchResponse;
    import org.elasticsearch.client.RequestOptions;
    import org.elasticsearch.client.RestClient;
    import org.elasticsearch.client.RestHighLevelClient;
    import org.elasticsearch.common.unit.Fuzziness;
    import org.elasticsearch.index.query.BoolQueryBuilder;
    import org.elasticsearch.index.query.QueryBuilders;
    import org.elasticsearch.index.query.RangeQueryBuilder;
    import org.elasticsearch.index.query.TermsQueryBuilder;
    import org.elasticsearch.search.SearchHit;
    import org.elasticsearch.search.SearchHits;
    import org.elasticsearch.search.aggregations.AggregationBuilder;
    import org.elasticsearch.search.aggregations.AggregationBuilders;
    import org.elasticsearch.search.builder.SearchSourceBuilder;
    import org.elasticsearch.search.fetch.subphase.highlight.HighlightBuilder;
    import org.elasticsearch.search.sort.SortOrder;
    
    public class ESTest_Doc_Query {
        public static void main(String[] args) throws Exception {
    
            RestHighLevelClient esClient = new RestHighLevelClient(
                    RestClient.builder(new HttpHost("localhost", 9200, "http"))
            );
    
            // 1. 查询索引中全部的数据
    //        SearchRequest request = new SearchRequest();
    //        request.indices("user");
    //
    //        request.source(new SearchSourceBuilder().query(QueryBuilders.matchAllQuery()));
    //
    //        SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
    //
    //        SearchHits hits = response.getHits();
    //
    //        System.out.println(hits.getTotalHits());
    //        System.out.println(response.getTook());
    //
    //        for ( SearchHit hit : hits ) {
    //            System.out.println(hit.getSourceAsString());
    //        }
    
            // 2. 条件查询 : termQuery
    //        SearchRequest request = new SearchRequest();
    //        request.indices("user");
    //
    //        request.source(new SearchSourceBuilder().query(QueryBuilders.termQuery("age", 30)));
    //        SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
    //
    //        SearchHits hits = response.getHits();
    //
    //        System.out.println(hits.getTotalHits());
    //        System.out.println(response.getTook());
    //
    //        for ( SearchHit hit : hits ) {
    //            System.out.println(hit.getSourceAsString());
    //        }
    
            // 3. 分页查询
    //        SearchRequest request = new SearchRequest();
    //        request.indices("user");
    //
    //        SearchSourceBuilder builder = new SearchSourceBuilder().query(QueryBuilders.matchAllQuery());
    //        // (当前页码-1)*每页显示数据条数
    //        builder.from(2);
    //        builder.size(2);
    //        request.source(builder);
    //        SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
    //
    //        SearchHits hits = response.getHits();
    //
    //        System.out.println(hits.getTotalHits());
    //        System.out.println(response.getTook());
    //
    //        for ( SearchHit hit : hits ) {
    //            System.out.println(hit.getSourceAsString());
    //        }
    
    //        // 4. 查询排序
    //        SearchRequest request = new SearchRequest();
    //        request.indices("user");
    //
    //        SearchSourceBuilder builder = new SearchSourceBuilder().query(QueryBuilders.matchAllQuery());
    //        //
    //        builder.sort("age", SortOrder.DESC);
    //
    //        request.source(builder);
    //        SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
    //
    //        SearchHits hits = response.getHits();
    //
    //        System.out.println(hits.getTotalHits());
    //        System.out.println(response.getTook());
    //
    //        for ( SearchHit hit : hits ) {
    //            System.out.println(hit.getSourceAsString());
    //        }
    
    //        // 5. 过滤字段
    //        SearchRequest request = new SearchRequest();
    //        request.indices("user");
    //
    //        SearchSourceBuilder builder = new SearchSourceBuilder().query(QueryBuilders.matchAllQuery());
    //        //
    //        String[] excludes = {"age"};
    //        String[] includes = {};
    //        builder.fetchSource(includes, excludes);
    //
    //        request.source(builder);
    //        SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
    //
    //        SearchHits hits = response.getHits();
    //
    //        System.out.println(hits.getTotalHits());
    //        System.out.println(response.getTook());
    //
    //        for ( SearchHit hit : hits ) {
    //            System.out.println(hit.getSourceAsString());
    //        }
    
    //        // 6. 组合查询
    //        SearchRequest request = new SearchRequest();
    //        request.indices("user");
    //
    //        SearchSourceBuilder builder = new SearchSourceBuilder();
    //        BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
    //
    //        //boolQueryBuilder.must(QueryBuilders.matchQuery("age", 30));
    //        //boolQueryBuilder.must(QueryBuilders.matchQuery("sex", "男"));
    //        //boolQueryBuilder.mustNot(QueryBuilders.matchQuery("sex", "男"));
    //        boolQueryBuilder.should(QueryBuilders.matchQuery("age", 30));
    //        boolQueryBuilder.should(QueryBuilders.matchQuery("age", 40));
    //
    //        builder.query(boolQueryBuilder);
    //
    //        request.source(builder);
    //        SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
    //
    //        SearchHits hits = response.getHits();
    //
    //        System.out.println(hits.getTotalHits());
    //        System.out.println(response.getTook());
    //
    //        for ( SearchHit hit : hits ) {
    //            System.out.println(hit.getSourceAsString());
    //        }
    
    //        // 7. 范围查询
    //        SearchRequest request = new SearchRequest();
    //        request.indices("user");
    //
    //        SearchSourceBuilder builder = new SearchSourceBuilder();
    //        RangeQueryBuilder rangeQuery = QueryBuilders.rangeQuery("age");
    //
    //        rangeQuery.gte(30);
    //        rangeQuery.lt(50);
    //
    //        builder.query(rangeQuery);
    //
    //        request.source(builder);
    //        SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
    //
    //        SearchHits hits = response.getHits();
    //
    //        System.out.println(hits.getTotalHits());
    //        System.out.println(response.getTook());
    //
    //        for ( SearchHit hit : hits ) {
    //            System.out.println(hit.getSourceAsString());
    //        }
    
            // 8. 模糊查询
    //        SearchRequest request = new SearchRequest();
    //        request.indices("user");
    //
    //        SearchSourceBuilder builder = new SearchSourceBuilder();
    //        builder.query(QueryBuilders.fuzzyQuery("name", "wangwu").fuzziness(Fuzziness.TWO));
    //
    //        request.source(builder);
    //        SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
    //
    //        SearchHits hits = response.getHits();
    //
    //        System.out.println(hits.getTotalHits());
    //        System.out.println(response.getTook());
    //
    //        for ( SearchHit hit : hits ) {
    //            System.out.println(hit.getSourceAsString());
    //        }
    
    //        // 9. 高亮查询
    //        SearchRequest request = new SearchRequest();
    //        request.indices("user");
    //
    //        SearchSourceBuilder builder = new SearchSourceBuilder();
    //        TermsQueryBuilder termsQueryBuilder = QueryBuilders.termsQuery("name", "zhangsan");
    //
    //        HighlightBuilder highlightBuilder = new HighlightBuilder();
    //        highlightBuilder.preTags("<font color='red'>");
    //        highlightBuilder.postTags("</font>");
    //        highlightBuilder.field("name");
    //
    //        builder.highlighter(highlightBuilder);
    //        builder.query(termsQueryBuilder);
    //
    //        request.source(builder);
    //        SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
    //
    //        SearchHits hits = response.getHits();
    //
    //        System.out.println(hits.getTotalHits());
    //        System.out.println(response.getTook());
    //
    //        for ( SearchHit hit : hits ) {
    //            System.out.println(hit.getSourceAsString());
    //        }
    
    //        // 10. 聚合查询
    //        SearchRequest request = new SearchRequest();
    //        request.indices("user");
    //
    //        SearchSourceBuilder builder = new SearchSourceBuilder();
    //
    //        AggregationBuilder aggregationBuilder = AggregationBuilders.max("maxAge").field("age");
    //        builder.aggregation(aggregationBuilder);
    //
    //        request.source(builder);
    //        SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
    //
    //        SearchHits hits = response.getHits();
    //
    //        System.out.println(hits.getTotalHits());
    //        System.out.println(response.getTook());
    //
    //        for ( SearchHit hit : hits ) {
    //            System.out.println(hit.getSourceAsString());
    //        }
    
            // 11. 分组查询
            SearchRequest request = new SearchRequest();
            request.indices("user");
    
            SearchSourceBuilder builder = new SearchSourceBuilder();
    
            AggregationBuilder aggregationBuilder = AggregationBuilders.terms("ageGroup").field("age");
            builder.aggregation(aggregationBuilder);
    
            request.source(builder);
            SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
    
            SearchHits hits = response.getHits();
    
            System.out.println(hits.getTotalHits());
            System.out.println(response.getTook());
    
            for ( SearchHit hit : hits ) {
                System.out.println(hit.getSourceAsString());
            }
    
    
    
            esClient.close();
        }
    }

    本文来自博客园,作者:秋华,转载请注明原文链接:https://www.cnblogs.com/qiu-hua/p/15216677.html

  • 相关阅读:
    Hdu 4496 D-City
    Hdu 1213 How Many Tables
    T1387:搭配购买(buy)
    codevs 2597 团伙
    Hdu 1232 畅通工程
    RQNOJ PID331 家族
    提高组day4
    xjoi2018提高组训训练25
    关于upp和lower
    矩阵快速幂求fib
  • 原文地址:https://www.cnblogs.com/qiu-hua/p/15216677.html
Copyright © 2020-2023  润新知