我是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可以使用)
非常感谢任何帮助!
答案 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());
}