Elastic Search 1.7:在嵌套术语聚合中返回空桶

Elastic Search 1.7: Returning Empty Buckets in Nested Terms Aggregation

我这里有一个聚合查询是:

Return the number of Records by Type, grouped by Creator in the last 6 months.

查询如下:

GET /test/records/_search?search_type=count
{
  "aggs": {
    "timeRange": {
      "filter": {
        "range": {
          "When": {
            "gte": "now-6M",
            "lte": "now"
          }
        }
      },
      "aggs": {
        "groupBy": {
          "terms": {
            "field": "Creator",
            "min_doc_count": 0
          },
          "aggs": {
            "counts": {
              "terms": {
                "field": "Type",
                "min_doc_count": 0
              }
            }
          }
        }
      }
    }
  }
}

结果显示为:

{
   "took": 11,
   "timed_out": false,
   "_shards": {
      "total": 1,
      "successful": 1,
      "failed": 0
   },
   "hits": {
      "total": 261,
      "max_score": 0,
      "hits": []
   },
   "aggregations": {
      "timeRange": {
         "doc_count": 192,
         "groupBy": {
            "doc_count_error_upper_bound": 0,
            "sum_other_doc_count": 0,
            "buckets": [
               {
                  "key": "ff94d50a-9ced-4877-85cc-a08a00fd49f4",
                  "doc_count": 175,
                  "counts": {
                     "doc_count_error_upper_bound": 0,
                     "sum_other_doc_count": 3,
                     "buckets": [
                        {
                           "key": "9f937783-dc28-421c-a937-a0c201643aae",
                           "doc_count": 95
                        },
                        {
                           "key": "36e4b200-e8ca-47f5-b9bb-a09101058595",
                           "doc_count": 31
                        },
                        {
                           "key": "cf421f05-37b1-470e-9ab9-a0bb0100792d",
                           "doc_count": 11
                        }
                     ]
                  }
               },
               {
                  "key": "be8ca900-0011-0002-1976-c737a7e00000",
                  "doc_count": 0,
                  "counts": {
                     "doc_count_error_upper_bound": 0,
                     "sum_other_doc_count": 0,
                     "buckets": []
                  }
               },
               {
                  "key": "fae866a8-705e-e111-bd17-d6ec07ced130",
                  "doc_count": 0,
                  "counts": {
                     "doc_count_error_upper_bound": 0,
                     "sum_other_doc_count": 0,
                     "buckets": []
                  }
               }
            ]
         }
      }
   }
}

从上面列出的结果来看,当术语聚合中的计数为 0 时,它不会为低于它的级别的术语列出 0。

My question is: Is it possible to have it show 0 counts for in these scenarios?

所需输出示例如下:

{
   "took": 11,
   "timed_out": false,
   "_shards": {
      "total": 1,
      "successful": 1,
      "failed": 0
   },
   "hits": {
      "total": 261,
      "max_score": 0,
      "hits": []
   },
   "aggregations": {
      "timeRange": {
         "doc_count": 192,
         "groupBy": {
            "doc_count_error_upper_bound": 0,
            "sum_other_doc_count": 0,
            "buckets": [
               {
                  "key": "ff94d50a-9ced-4877-85cc-a08a00fd49f4",
                  "doc_count": 175,
                  "counts": {
                     "doc_count_error_upper_bound": 0,
                     "sum_other_doc_count": 3,
                     "buckets": [
                        {
                           "key": "9f937783-dc28-421c-a937-a0c201643aae",
                           "doc_count": 95
                        },
                        {
                           "key": "36e4b200-e8ca-47f5-b9bb-a09101058595",
                           "doc_count": 31
                        },
                        {
                           "key": "cf421f05-37b1-470e-9ab9-a0bb0100792d",
                           "doc_count": 11
                        }
                     ]
                  }
               },
               {
                  "key": "be8ca900-0011-0002-1976-c737a7e00000",
                  "doc_count": 0,
                  "counts": {
                     "doc_count_error_upper_bound": 0,
                     "sum_other_doc_count": 0,
                     "buckets": [
                        {
                           "key": "9f937783-dc28-421c-a937-a0c201643aae",
                           "doc_count": 0
                        },
                        {
                           "key": "36e4b200-e8ca-47f5-b9bb-a09101058595",
                           "doc_count": 0
                        },
                        {
                           "key": "cf421f05-37b1-470e-9ab9-a0bb0100792d",
                           "doc_count": 0
                        }
                     ]
                  }
               },
               {
                  "key": "fae866a8-705e-e111-bd17-d6ec07ced130",
                  "doc_count": 0,
                  "counts": {
                     "doc_count_error_upper_bound": 0,
                     "sum_other_doc_count": 0,
                     "buckets": [
                        {
                           "key": "9f937783-dc28-421c-a937-a0c201643aae",
                           "doc_count": 0
                        },
                        {
                           "key": "36e4b200-e8ca-47f5-b9bb-a09101058595",
                           "doc_count": 0
                        },
                        {
                           "key": "cf421f05-37b1-470e-9ab9-a0bb0100792d",
                           "doc_count": 0
                        }
                     ]
                  }
               }
            ]
         }
      }
   }
}

这是 Clemens Klein-Robbenhaar 对主要 post 的评论回答。简而言之:我知道期望值是什么,但 Elasticsearch 不知道。一旦统计到该组的聚合总数为0,它就不知道在那下面搜索什么了,因为什么都没有。