java操作es聚合操作并显示其他字段_java操作elasticsearch实现组合桶聚合

1、terms分组查询

//分组聚合

@Test

public void test40() throws UnknownHostException{

//1、指定es集群 cluster.name 是固定的key值,my-application是ES集群的名称

Settings settings = Settings.builder().put("cluster.name", "my-application").build();

//2.创建访问ES服务器的客户端

TransportClient client = new PreBuiltTransportClient(settings)

.addTransportAddress(new TransportAddress(InetAddress.getByName("192.168.1.94"), 9300));

//以年龄分组,组名为:terms

AggregationBuilder builder = AggregationBuilders.terms("terms").field("age");

SearchResponse response = client.prepareSearch("lib3").addAggregation(builder).execute().actionGet();

Terms terms = response.getAggregations().get("terms");

for(Terms.Bucket term:terms.getBuckets()) {

System.out.println(term.getKey()+" "+term.getDocCount());

}

}

2、terms query聚合查询

//filter聚合

@Test

public void test41() throws UnknownHostException{

//1、指定es集群 cluster.name 是固定的key值,my-application是ES集群的名称

Settings settings = Settings.builder().put("cluster.name", "my-application").build();

//2.创建访问ES服务器的客户端

TransportClient client = new PreBuiltTransportClient(settings)

.addTransportAddress(new TransportAddress(InetAddress.getByName("192.168.1.94"), 9300));

//以年龄分组,并查询年龄为20的有多少人

QueryBuilder queryBuilder = QueryBuilders.termQuery("age", 20);

AggregationBuilder builder = AggregationBuilders.filter("filter",queryBuilder);

SearchResponse response = client.prepareSearch("lib3").addAggregation(builder).execute().actionGet();

Filter filter = response.getAggregations().get("filter");

System.out.println(filter.getDocCount());

}

3、filters聚合

//filters聚合:指定多个过滤条件

@Test

public void test42() throws UnknownHostException{

//1、指定es集群 cluster.name 是固定的key值,my-application是ES集群的名称

Settings settings = Settings.builder().put("cluster.name", "my-application").build();

//2.创建访问ES服务器的客户端

TransportClient client = new PreBuiltTransportClient(settings)

.addTransportAddress(new TransportAddress(InetAddress.getByName("192.168.1.94"), 9300));

//查询heijiu changge中各有多少个文档

QueryBuilder queryBuilder = QueryBuilders.termQuery("interests", "hejiu");

QueryBuilder queryBuilder2 = QueryBuilders.termQuery("interests", "changge");

AggregationBuilder builder = AggregationBuilders.filters("filters",queryBuilder,queryBuilder2);

SearchResponse response = client.prepareSearch("lib3").addAggregation(builder).execute().actionGet();

Aggregation filter = response.getAggregations().get("filters");

System.out.println(filter.toString());

}

4、range聚合

//range聚合:范围分组过滤条件

@Test

public void test43() throws UnknownHostException{

//1、指定es集群 cluster.name 是固定的key值,my-application是ES集群的名称

Settings settings = Settings.builder().put("cluster.name", "my-application").build();

//2.创建访问ES服务器的客户端

TransportClient client = new PreBuiltTransportClient(settings)

.addTransportAddress(new TransportAddress(InetAddress.getByName("192.168.1.94"), 9300));

//统计年龄在50以下的,年龄在25至50之间,年龄在25以上的人数

AggregationBuilder builder = AggregationBuilders

.range("range")

.field("age")

.addUnboundedTo(50)

.addRange(25,50)

.addUnboundedFrom(25);

SearchResponse response = client.prepareSearch("lib3").addAggregation(builder).execute().actionGet();

Aggregation filter = response.getAggregations().get("range");

System.out.println(filter.toString());

}

5、missing聚合

//missing聚合:为空聚合统计

@Test

public void test44() throws UnknownHostException{

//1、指定es集群 cluster.name 是固定的key值,my-application是ES集群的名称

Settings settings = Settings.builder().put("cluster.name", "my-application").build();

//2.创建访问ES服务器的客户端

TransportClient client = new PreBuiltTransportClient(settings)

.addTransportAddress(new TransportAddress(InetAddress.getByName("192.168.1.94"), 9300));

//统计价格为空的个数

AggregationBuilder builder = AggregationBuilders.missing("missing").field("price");

SearchResponse response = client.prepareSearch("lib4").addAggregation(builder).execute().actionGet();

Aggregation filter = response.getAggregations().get("missing");

System.out.println(filter.toString());

}

下一篇博客本人将书写java操作elasticsearch实现集群管理。对后期博客感兴趣的朋友可以关注交流,转发请说明出处,本人的博客地址为:https://www.cnblogs.com/chenyuanbo/

技术在于交流!

java操作elasticsearch实现query String

1.CommonTersQuery: 指定字段进行模糊查询 //commonTermsQuery @Test public void test35() throws UnknownHostExcept ...

java操作elasticsearch实现聚合查询

1.max 最大值 //max 求最大值 @Test public void test30() throws UnknownHostException{ //1.指定es集群 cluster.name ...

java操作elasticsearch实现前缀查询、wildcard、fuzzy模糊查询、ids查询

1.前缀查询(prefix) //prefix前缀查询 @Test public void test15() throws UnknownHostException { //1.指定es集群 clus ...

java操作elasticsearch实现条件查询(match、multiMatch、term、terms、reange)

1.条件match query查询 //条件查询match query @Test public void test10() throws UnknownHostException { //1.指定e ...

java操作elasticsearch实现查询删除和查询所有

后期博客本人都只给出代码,具体的说明在代码中也有注释. 1.查询删除 //查询删除:将查询到的数据进行删除 @Test public void test8() throws UnknownHostEx ...

java操作elasticsearch实现批量添加数据(bulk)

java操作elasticsearch实现批量添加主要使用了bulk 代码如下: //bulk批量操作(批量添加) @Test public void test7() throws IOExcepti ...

java操作elasticsearch实现基本的增删改查操作

一.在进行java操作elasticsearch之前,请确认好集群的名称及对应的ES节点ip和端口 1.查看ES的集群名称 #进入elasticsearch.yml配置文件/opt/elasticse ...

Java操作ElasticSearch之创建客户端连接

Java操作ElasticSearch之创建客户端连接 3 发布时间:『 2017-09-11 17:02』  博客类别:elasticsearch  阅读(3157) Java操作ElasticSe ...

java 操作elasticsearch之搭建测试项目环境

在创建项目之前请确认maven是否安装好,在此我是以环境都搭建好的情况下进行示范,现在以eclipse开发工具为例,具体操作如下: 1.创建maven项目 File - new -other 2.在p ...

随机推荐

java CyclicBarrier

import java.io.IOException; import java.util.Random; import java.util.concurrent.BrokenBarrierExcept ...

IO中同步、异步与阻塞、非阻塞的区别(转)

转自:http://blog.chinaunix.net/uid-26000296-id-3754118.html 一.同步与异步同步/异步, 它们是消息的通知机制 1. 概念解释A. 同步所谓同步, ...

JS(一)

循环还是很有意思的: 1) 安全数的作业:

ubuntu 10.4非法关机后上不了网

用的好好的ubuntu 10.4,非法关机后居然上不了网,右上角的网络图标也不见了,还以为是网卡问题,进入xp,发现一切正常,心里不断地诅咒ubuntu,该死的ubuntu,我windows还天天非法 ...

详解HTTPS加速原理

HTTPS是什么? http叫超文本传输协议,使用TCP端口80,默认情况下数据是明文传送的,数据可以通过抓包工具捕获到,因此在interner上,有些比较重要的站点的http服务器需要使用PKI(公 ...

JavaWeb 例子 JDBC+JSP登陆注册留言板

注册页面:

Ural 1966 Cycling Roads

================ Cycling Roads ================   Description When Vova was in Shenzhen, he rented a ...

Elastic Story(一)

关于_all 当索引一个文档的时候,Elasticsearch 取出所有字段的值拼接成一个大的字符串,作为 _all 字段进行索引.例如,当索引这个文档时: { "tweet": ...

python的学习之路day4

大纲 1.一些常用的内置函数 callable() chr() & ord() 随机生成验证码 map() 全局变量,局部变量 hash() & round() max() min() ...

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值