【发布时间】:2016-12-04 06:03:38
【问题描述】:
不确定如何提出问题。 我正在使用 Elasticsearch 2.2。
让我们从一个由 5 个文档组成的数据集示例开始:
[
{
"header": {
"called_entity": { "uuid": "a" },
"coverage_entity": {},
"sucessful_transfers": 1
}
},
{
"header": {
"called_entity": { "uuid": "a" },
"coverage_entity": { "uuid": "b" },
"sucessful_transfers": 1
}
},
{
"header": {
"called_entity": { "uuid": "b" },
"coverage_entity": { "uuid": "a" },
"sucessful_transfers": 1
}
},
{
"header": {
"called_entity": { "uuid": "b" },
"coverage_entity": { "uuid": "a" },
"sucessful_transfers": 0
}
}
]
called_entity 总是有一个 uuid。 coverage_entity 可以为空,或具有 uuid。
我使用脚本在 called_entity.uuid 或 coverage_entity.uuid 上进行聚合:
{
"size": 0,
"query": {
"match_all": {}
},
"aggs": {
"dim1": {
"terms": {
"script" : "return doc['header.called_entity.uuid'] + doc['header.coverage_entity.uuid']",
"size": 10
},
"aggs": {
"successful_transfers": {
"sum": {
"field": "header.successful_transfers"
}
}
}
}
}
}
所以现在,聚合已从 header.called_entity.uuid 或 header.coverage_entity.uuid 生成术语。
如何使用聚合键的值过滤我的聚合?例如,如果我想计算,对于每个桶,有多少文档的 uuid 仅取自 header.called_entity.uuid。类似的东西:
{
"size": 0,
"query": {
"match_all": {}
},
"aggs": {
"dim1": {
"terms": {
"script" : "return doc['header.called_entity.uuid'] + doc['header.coverage_entity.uuid']",
"size": 10
},
"aggs": {
"successful_transfers": {
"sum": {
"field": "header.successful_transfers"
}
},
"from_called_entity": {
"filter": {
"term": { "header.called_entity.uuid": BUCKET_KEY }
}
}
}
}
}
}
【问题讨论】:
标签: elasticsearch elasticsearch-aggregation