springboot + elasticsearch 进行Bucketing聚合操作

aggregations 包含 bucketing metric matrix pipeline

Bucketing
A family of aggregations that build buckets, where each bucket is associated with a key and a document criterion. When the aggregation is executed, all the buckets criteria are evaluated on every document in the context and when a criterion matches, the document is considered to "fall in" the relevant bucket. By the end of the aggregation process, we’ll end up with a list of buckets - each one with a set of documents that "belong" to it.

实体类

@Data
@Document(indexName = "es-customer",
        type = "customer",
        shards = 2,
        replicas = 1, refreshInterval = "-1")
public class Customer {

    @Id
    private String id;

    @Field(type = FieldType.Keyword
           )
    private String firstName;

    private String lastName;

    private Boolean valid;

    private Integer age;

    private Date createTime;
}

es里 数据

Customer(id=4_lguWkB9U5ULlhWJ1QK, firstName=tom, lastName=001, valid=null, age=44, createTime=Tue Mar 26 17:41:20 CST 2019)
Customer(id=5PlguWkB9U5ULlhWJ1Q5, firstName=lily, lastName=002, valid=null, age=56, createTime=Tue Mar 26 17:41:20 CST 2019)
Customer(id=5flguWkB9U5ULlhWJ1Rk, firstName=lily, lastName=004, valid=null, age=53, createTime=Tue Mar 26 17:41:20 CST 2019)
Customer(id=3_lguWkB9U5ULlhWJlQy, firstName=river 1, lastName=007, valid=null, age=12, createTime=Tue Mar 26 17:41:20 CST 2019)
Customer(id=4PlguWkB9U5ULlhWJlR6, firstName=Lucy 1, lastName=001, valid=null, age=13, createTime=Tue Mar 26 17:41:20 CST 2019)
Customer(id=4flguWkB9U5ULlhWJlSp, firstName=Lucy, lastName=002, valid=null, age=22, createTime=Tue Mar 26 17:41:20 CST 2019)
Customer(id=4vlguWkB9U5ULlhWJlTc, firstName=frank, lastName=001, valid=null, age=33, createTime=Tue Mar 26 17:41:20 CST 2019)
Customer(id=5vlguWkB9U5ULlhWJ1SN, firstName=tom, lastName=002, valid=null, age=66, createTime=Tue Mar 26 17:41:20 CST 2019)
Customer(id=5_lguWkB9U5ULlhWJ1S2, firstName=tom, lastName=005, valid=null, age=33, createTime=Tue Mar 26 17:41:20 CST 2019)

进行聚合操作

 @Test
    public void aggregationTest(){
        //获取注解,通过注解可以得到 indexName 和 type
        Document document = Customer.class.getAnnotation(Document.class);
        // 构建查询 , Aggregation 中 nameCount 为聚合的结果,firstName 为字段名称
        SearchQuery searchQuery = new NativeSearchQueryBuilder()
                .withQuery(matchAllQuery())
                .withSearchType(SearchType.QUERY_THEN_FETCH)
                .withIndices(document.indexName()).withTypes(document.type())
                .addAggregation(AggregationBuilders.terms("nameCount").field("firstName"))
                .build();

        // 聚合的结果
        Aggregations aggregations = elasticsearchTemplate.query(searchQuery, response -> response.getAggregations());
        Map<String, Aggregation> results = aggregations.asMap();
        StringTerms stringTerms= (StringTerms) results.get("nameCount");
        // 将bucket list 转换成 map , key -> 名字   value-> 出现次数
        Map<String,Long> nameCountMap = stringTerms.getBuckets()
                .stream()
                .collect(Collectors.toMap(
                        StringTerms.Bucket::getKeyAsString,
                        InternalTerms.Bucket::getDocCount,
                        (x,y)->x)
                );
        System.out.println(nameCountMap);

    }

返回结果

{frank=1, tom=3, lily=2, Lucy=1, river 1=1, Lucy 1=1}

参考地址
https://www.elastic.co/guide/en/elasticsearch/reference/6.3/search-aggregations.html#search-aggregations
https://blog.csdn.net/Topdandan/article/details/81436141
https://my.oschina.net/u/3664884/blog/1814423

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 225,565评论 6 525
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 96,696评论 3 406
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 172,935评论 0 370
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 61,327评论 1 303
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 70,338评论 6 401
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 53,760评论 1 316
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 42,085评论 3 431
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 41,091评论 0 280
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 47,656评论 1 327
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 39,657评论 3 348
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 41,767评论 1 355
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 37,360评论 5 351
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 43,088评论 3 341
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 33,493评论 0 25
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 34,654评论 1 278
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 50,374评论 3 383
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 46,841评论 2 367

推荐阅读更多精彩内容