我有一个排序的弹性搜索直方图聚合,可以正常工作。
我需要从每个聚合桶的第一个和最后一个文档返回一个字段。
当前查询(ruby风格的语法):
{
query: {
filtered: {
filter: {
bool: {
must: [
{ term: { some_id: 'something' } },
{ range: {
completed_at: {
gte: start,
lte: end
}
}
}
]
}
},
_cache: true,
_cache_key: "special-query"
}
},
aggs: {
intervals: {
histogram: {
field: 'completed_at',
interval: 24.hours.to_i,
min_doc_count: 0,
order: { _key: 'asc' }
},
aggs: {
start_at: { min: { field: 'completed_at' } },
end_at: { max: { field: 'completed_at' } },
price_stats: { extended_stats: { field: 'rate' } },
}
}
}
}
我搜索了文档并广泛搜索,但找不到任何解决方案。目前,我必须向数据库发送第二个查询以显式获取此字段的所有值,但我想将该功能转移到我的elasticsearch查询中。
答案 0 :(得分:6)
您希望每个聚合返回一个结果吗?
这称为Field Collapsing,遗憾的是Elasticsearch尚未提供,请参阅:https://github.com/elasticsearch/elasticsearch/issues/256
2014年9月更新
根据以下评论中的@bpierce:现在Elasticsearch 1.3.x已经出局,可以通过top_hits聚合获得字段折叠。我目前在类似于这个的查询中使用它。