栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

【elasticsearch系列】javaApi高级查询

【elasticsearch系列】javaApi高级查询

全匹配查询
// 创建客户端
RestHighLevelClient esClient=new RestHighLevelClient(
  RestClient.builder(new HttpHost("localhost",9200,"http"))
);
// 创建查询对象
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());
for(SearchHit hit: hits){
  // 打印每一项
  System.out.println(hit.getSourceAsString());
}
// 关闭客户端
esClient.close();
结果
7 hits
{"name":"张三","age":18,"sex":"女"}
{"name":"zhangsan","age":20,"sex":"男"}
{"name":"lisi","age":50,"sex":"女"}
{"name":"zhangsan1","age":30,"sex":"男"}
{"name":"lisi1","age":40,"sex":"男"}
{"name":"zhangsan2","age":40,"sex":"女"}
{"name":"lisi2","age":18,"sex":"男"}
条件查询
// 创建客户端
RestHighLevelClient esClient=new RestHighLevelClient(
  RestClient.builder(new HttpHost("47.94.217.248",9200,"http"))
);
// 创建查询对象
SearchRequest request=new SearchRequest();
// 设置索引
request.indices("user");
// 设置查询条件
// 查询年龄等于30的
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());
for(SearchHit hit: hits){
  // 打印每一项
  System.out.println(hit.getSourceAsString());
}
// 关闭客户端
esClient.close();
分页查询
// 创建客户端
RestHighLevelClient esClient=new RestHighLevelClient(
  RestClient.builder(new HttpHost("localhost",9200,"http"))
);
// 创建查询对象
SearchRequest request=new SearchRequest();
// 设置索引
request.indices("user");
// 设置查询条件
SearchSourceBuilder builder = new SearchSourceBuilder().query(QueryBuilders.matchAllQuery());
// 设置分页条件
// (当前页码-1)*每页显示数据条数
builder.from(0);
builder.size(2);
request.source(builder);
SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
SearchHits hits = response.getHits();
// 打印命中条数
System.out.println(hits.getTotalHits());
for(SearchHit hit: hits){
  // 打印每一项
  System.out.println(hit.getSourceAsString());
}
// 关闭客户端
esClient.close();
结果
7 hits
{"name":"张三","age":18,"sex":"女"}
{"name":"zhangsan","age":20,"sex":"男"}
过滤字段
// 创建客户端
RestHighLevelClient esClient=new RestHighLevelClient(
  RestClient.builder(new HttpHost("localhost",9200,"http"))
);
// 创建查询对象
SearchRequest request=new SearchRequest();
// 设置索引
request.indices("user");
// 设置查询条件
SearchSourceBuilder builder = new SearchSourceBuilder().query(QueryBuilders.matchAllQuery());
// 设置过滤条件
// 只查询包含name 的文档内容
String[] exclude={};// 可以指定排除字段
String[] include={"name"};
builder.fetchSource(include,exclude);
request.source(builder);
SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
SearchHits hits = response.getHits();
// 打印命中条数
System.out.println(hits.getTotalHits());
for(SearchHit hit: hits){
  // 打印每一项
  System.out.println(hit.getSourceAsString());
}
// 关闭客户端
esClient.close();
结果
7 hits
{"name":"张三"}
{"name":"zhangsan"}
{"name":"lisi"}
{"name":"zhangsan1"}
{"name":"lisi1"}
{"name":"zhangsan2"}
{"name":"lisi2"}
组合查询
//组合查询
// 创建客户端
RestHighLevelClient esClient=new RestHighLevelClient(
  RestClient.builder(new HttpHost("localhost",9200,"http"))
);
// 创建查询对象
SearchRequest request=new SearchRequest();
// 设置索引
request.indices("user");
// 设置组合查询条件
SearchSourceBuilder builder = new SearchSourceBuilder();
BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
boolQueryBuilder.must(QueryBuilders.matchQuery("sex","男"));
boolQueryBuilder.must(QueryBuilders.matchQuery("age",30));
// 查询年龄30或者40的
//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());
for(SearchHit hit: hits){
  // 打印每一项
  System.out.println(hit.getSourceAsString());
}
// 关闭客户端
esClient.close();
查询结果
1 hits
{"name":"zhangsan1","age":30,"sex":"男"}
范围查询
//范围查询
// 创建客户端
RestHighLevelClient esClient=new RestHighLevelClient(
  RestClient.builder(new HttpHost("47.94.217.248",9200,"http"))
);
// 创建查询对象
SearchRequest request=new SearchRequest();
// 设置索引
request.indices("user");
// 设置范围查询条件
SearchSourceBuilder builder = new SearchSourceBuilder();
RangeQueryBuilder rangeQuery = QueryBuilders.rangeQuery("age");
// 30=<年龄<=40
rangeQuery.gte(30); //gt: 大于
rangeQuery.lte(40); //lt: 小于
builder.query(rangeQuery);
request.source(builder);
SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
SearchHits hits = response.getHits();
// 打印命中条数
System.out.println(hits.getTotalHits());
for(SearchHit hit: hits){
  // 打印每一项
  System.out.println(hit.getSourceAsString());
}
// 关闭客户端
esClient.close();
结果
3 hits
{"name":"zhangsan1","age":30,"sex":"男"}
{"name":"lisi1","age":40,"sex":"男"}
{"name":"zhangsan2","age":40,"sex":"女"}
模糊查询
//模糊查询
// 创建客户端
RestHighLevelClient esClient=new RestHighLevelClient(
  RestClient.builder(new HttpHost("47.94.217.248",9200,"http"))
);
// 创建查询对象
SearchRequest request=new SearchRequest();
// 设置索引
request.indices("user");
// 设置模糊查询条件
SearchSourceBuilder builder = new SearchSourceBuilder();
// 模糊查询name=zhangsan的文档,允许差一位
builder.query(QueryBuilders.fuzzyQuery("name","zhangsan").fuzziness(Fuzziness.ONE));
request.source(builder);
SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
SearchHits hits = response.getHits();
// 打印命中条数
System.out.println(hits.getTotalHits());
for(SearchHit hit: hits){
  // 打印每一项
  System.out.println(hit.getSourceAsString());
}
// 关闭客户端
esClient.close();
结果
3 hits
{"name":"zhangsan","age":20,"sex":"男"}
{"name":"zhangsan1","age":30,"sex":"男"}
{"name":"zhangsan2","age":40,"sex":"女"}
高亮查询
//高亮查询
// 创建客户端
RestHighLevelClient esClient=new RestHighLevelClient(
  RestClient.builder(new HttpHost("47.94.217.248",9200,"http"))
);
// 创建查询对象
SearchRequest request=new SearchRequest();
// 设置索引
request.indices("user");
// 设置查询条件
SearchSourceBuilder builder = new SearchSourceBuilder();
TermQueryBuilder termQueryBuilder = QueryBuilders.termQuery("name", "zhangsan");
builder.query(termQueryBuilder);
// 设置高亮格式
HighlightBuilder highlightBuilder=new HighlightBuilder();
highlightBuilder.preTags("");
highlightBuilder.postTags("");
// 设置高亮字段
highlightBuilder.field("name");
builder.highlighter(highlightBuilder);
request.source(builder);
SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
SearchHits hits = response.getHits();
// 打印命中条数
System.out.println(hits.getTotalHits());
for(SearchHit hit: hits){
  // 打印每一项
  System.out.println(hit.getSourceAsString());
}
// 关闭客户端
esClient.close();
查询结果
{
    "took":2,
    "timed_out":false,
    "_shards":{
        "total":1,
        "successful":1,
        "skipped":0,
        "failed":0
    },
    "hits":{
        "total":{
            "value":1,
            "relation":"eq"
        },
        "max_score":1.7641908,
        "hits":[
            {
                "_index":"user",
                "_type":"_doc",
                "_id":"1002",
                "_score":1.7641908,
                "_source":{
                    "name":"zhangsan",
                    "age":20,
                    "sex":"[0xffffffe7][0xffffff94][0xffffffb7]"
                },
                "highlight":{
                    "name":[
                        "zhangsan"
                    ]
                }
            }
        ]
    }
}
聚合查询 最大年龄
// 创建客户端
RestHighLevelClient esClient=new RestHighLevelClient(
  RestClient.builder(new HttpHost("47.94.217.248",9200,"http"))
);
// 创建查询对象
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());
for(SearchHit hit: hits){
  // 打印每一项
  System.out.println(hit.getSourceAsString());
}
// 关闭客户端
esClient.close();
结果
{
    "took":2,
    "timed_out":false,
    "_shards":{
        "total":1,
        "successful":1,
        "skipped":0,
        "failed":0
    },
    "hits":{
        "total":{
            "value":7,
            "relation":"eq"
        },
        "max_score":1,
        "hits":[
            {
                "_index":"user",
                "_type":"_doc",
                "_id":"1001",
                "_score":1,
                "_source":{
                    "name":"[0xffffffe5][0xffffffbc][0xffffffa0][0xffffffe4][0xffffffb8][0xffffff89]",
                    "age":18,
                    "sex":"[0xffffffe5][0xffffffa5][0xffffffb3]"
                }
            },
            {
                "_index":"user",
                "_type":"_doc",
                "_id":"1002",
                "_score":1,
                "_source":{
                    "name":"zhangsan",
                    "age":20,
                    "sex":"[0xffffffe7][0xffffff94][0xffffffb7]"
                }
            },
            {
                "_index":"user",
                "_type":"_doc",
                "_id":"1003",
                "_score":1,
                "_source":{
                    "name":"lisi",
                    "age":50,
                    "sex":"[0xffffffe5][0xffffffa5][0xffffffb3]"
                }
            },
            {
                "_index":"user",
                "_type":"_doc",
                "_id":"1004",
                "_score":1,
                "_source":{
                    "name":"zhangsan1",
                    "age":30,
                    "sex":"[0xffffffe7][0xffffff94][0xffffffb7]"
                }
            },
            {
                "_index":"user",
                "_type":"_doc",
                "_id":"1005",
                "_score":1,
                "_source":{
                    "name":"lisi1",
                    "age":40,
                    "sex":"[0xffffffe7][0xffffff94][0xffffffb7]"
                }
            },
            {
                "_index":"user",
                "_type":"_doc",
                "_id":"1006",
                "_score":1,
                "_source":{
                    "name":"zhangsan2",
                    "age":40,
                    "sex":"[0xffffffe5][0xffffffa5][0xffffffb3]"
                }
            },
            {
                "_index":"user",
                "_type":"_doc",
                "_id":"1007",
                "_score":1,
                "_source":{
                    "name":"lisi2",
                    "age":18,
                    "sex":"[0xffffffe7][0xffffff94][0xffffffb7]"
                }
            }
        ]
    },
    "aggregations":{
        "max#maxAge":{
            "value":50
        }
    }
}
分组聚合查询
// 分组查询
// 创建客户端
RestHighLevelClient esClient=new RestHighLevelClient(
  RestClient.builder(new HttpHost("47.94.217.248",9200,"http"))
);
// 创建查询对象
SearchRequest request=new SearchRequest();
// 设置索引
request.indices("user");
// 设置查询条件
SearchSourceBuilder builder = new SearchSourceBuilder();
// 对age进行分组查询
AggregationBuilder aggregationBuilder = AggregationBuilders.terms("ageGroups").field("age");
builder.aggregation(aggregationBuilder);
request.source(builder);
SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);
SearchHits hits = response.getHits();
// 打印命中条数
System.out.println(hits.getTotalHits());
for(SearchHit hit: hits){
  // 打印每一项
  System.out.println(hit.getSourceAsString());
}
// 关闭客户端
esClient.close();
结果
{
    "took":1,
    "timed_out":false,
    "_shards":{
        "total":1,
        "successful":1,
        "skipped":0,
        "failed":0
    },
    "hits":{
        "total":{
            "value":7,
            "relation":"eq"
        },
        "max_score":1,
        "hits":[
            {
                "_index":"user",
                "_type":"_doc",
                "_id":"1001",
                "_score":1,
                "_source":{
                    "name":"[0xffffffe5][0xffffffbc][0xffffffa0][0xffffffe4][0xffffffb8][0xffffff89]",
                    "age":18,
                    "sex":"[0xffffffe5][0xffffffa5][0xffffffb3]"
                }
            },
            {
                "_index":"user",
                "_type":"_doc",
                "_id":"1002",
                "_score":1,
                "_source":{
                    "name":"zhangsan",
                    "age":20,
                    "sex":"[0xffffffe7][0xffffff94][0xffffffb7]"
                }
            },
            {
                "_index":"user",
                "_type":"_doc",
                "_id":"1003",
                "_score":1,
                "_source":{
                    "name":"lisi",
                    "age":50,
                    "sex":"[0xffffffe5][0xffffffa5][0xffffffb3]"
                }
            },
            {
                "_index":"user",
                "_type":"_doc",
                "_id":"1004",
                "_score":1,
                "_source":{
                    "name":"zhangsan1",
                    "age":30,
                    "sex":"[0xffffffe7][0xffffff94][0xffffffb7]"
                }
            },
            {
                "_index":"user",
                "_type":"_doc",
                "_id":"1005",
                "_score":1,
                "_source":{
                    "name":"lisi1",
                    "age":40,
                    "sex":"[0xffffffe7][0xffffff94][0xffffffb7]"
                }
            },
            {
                "_index":"user",
                "_type":"_doc",
                "_id":"1006",
                "_score":1,
                "_source":{
                    "name":"zhangsan2",
                    "age":40,
                    "sex":"[0xffffffe5][0xffffffa5][0xffffffb3]"
                }
            },
            {
                "_index":"user",
                "_type":"_doc",
                "_id":"1007",
                "_score":1,
                "_source":{
                    "name":"lisi2",
                    "age":18,
                    "sex":"[0xffffffe7][0xffffff94][0xffffffb7]"
                }
            }
        ]
    },
    "aggregations":{
        "lterms#ageGroups":{
            "doc_count_error_upper_bound":0,
            "sum_other_doc_count":0,
            "buckets":[
                {
                    "key":18,
                    "doc_count":2
                },
                {
                    "key":40,
                    "doc_count":2
                },
                {
                    "key":20,
                    "doc_count":1
                },
                {
                    "key":30,
                    "doc_count":1
                },
                {
                    "key":50,
                    "doc_count":1
                }
            ]
        }
    }
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/350102.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号