ElasticSearch Bucket Aggregations

时间:2017-06-27 16:40:57

标签: java elasticsearch jest elasticsearch-java-api

我是ElasticSearch聚合的新手。

通过阅读文档,我了解到在我的用例中我需要使用Bucket Aggregations。

但是,我无法找到任何可靠的文档/代码,它提供了如何为此构建查询的示例。我使用Jest作为我的客户与ElasticSearch交谈。

我的用例是:

假设我有以下文件:

{ name : 'abc' , field_1: '123' , field_2 : '3211' } , { name : 'abc' , field_1: '33' , field_2 : '011' }, { name : 'xyz' , field_1: '33' , field_2 : '011' } , { name : 'xyz' , field_1: '33' , field_2 : '011' }

当我查询ES时,我希望结果按字段分组' name'

因此返回的文档将是那种类型:

{
 { name : 'abc' , 
     aggregation : { 
     { 
           field_1 : '123' , field_2 : '3211' 
       } ,

     { 
           field_1 : '33' , field_2 : '011' 
       } ,

}

} 

,

{ name : 'xyz' , 
     aggregation : { 
     { 
           field_1 : '123' , field_2 : '3211' 
       } ,

     { 
           field_1 : '33' , field_2 : '011' 
       } ,

}

}

}

我无法在ElastcSearch中使用Jest /使用SearchSourceBuilders找到任何示例代码(Jest可以使用)

非常感谢任何帮助!

1 个答案:

答案 0 :(得分:1)

看看这个合并的pull request到Jest。你可以在那里找到一个很好的代码示例。它与您在问题中描述的解决方案不完全相同,但它是实现接近您想要的结果的唯一可能方式。 另外,看一下pull请求的测试。 for(Entry entry : termBuckets) { TopHitsAggregation topHitAgg = entry.getTopHitsAggregation("top_hits_test"); List<String> hits = topHitAgg.getSourceAsStringList(); assertEquals(2, hits.size()); } 似乎接近你想要的。