合规国际互联网加速 OSASE为企业客户提供高速稳定SD-WAN国际加速解决方案。 广告
# Bucket Selector Aggregation(桶选择器聚合) 父管道聚合,它执行一个脚本,该脚本确定当前桶是否将保留在父多桶聚合中。指定度量必须是数字,脚本必须返回一个布尔值。如果脚本语言是表达式,则允许数字返回值。在这种情况下,0.0将被判定为false,所有的其他值将被判定为true。 注意:bucket_selector聚合,像所有管道聚合,在所有的其他同级聚合后执行。这意味着使用bucket_selector聚合过滤返回的响应数据中不会保存运行时的聚合。 ## Syntax(语法) bucket_selector聚合看起来像这样: | `{` `"bucket_selector"``: {` `"buckets_path"``: {` `"my_var1"``: ``"the_sum"``,                     #``1` `"my_var2"``: ``"the_value_count"` `},` `"script"``: ``"params.my_var1 > params.my_var2"` `}` `}` | | 1 | 这里,my_var1是这个桶的路径中使用脚本中的变量的名称,the_sum是路径的度量所使用的变量。 | ## Table 12. `bucket_selector` Parameters(Table 12.bucket_selector参数) | 参数名称 | 描述 | 是否必要 | 默认值 | | --- | --- | --- | --- | | `script` | 在这个聚合上运行的脚本。这个脚本可以是内置的,文件或索引。(详细信息,请参阅Scripting) | 必须 |   | | `buckets_path` | 脚本变量的映射,以及我们希望用于桶的变量的相关路径(相关详细信息,请参阅“buckets_path Syntax”一节) | 必须 |   | | `gap_policy` | 在数据中找到差异时应用的策略(相关详情:请参阅“Dealing with gaps in the data”一节) | 可选 | `skip` | 以下代码仅保留了该月份的总销售额超过400的数据桶: | `POST /sales/_search` `{` `"size"``: ``0``,` `"aggs"` `: {` `"sales_per_month"` `: {` `"date_histogram"` `: {` `"field"` `: ``"date"``,` `"interval"` `: ``"month"` `},` `"aggs"``: {` `"total_sales"``: {` `"sum"``: {` `"field"``: ``"price"` `}` `},` `"sales_bucket_filter"``: {` `"bucket_selector"``: {` `"buckets_path"``: {` `"totalSales"``: ``"total_sales"` `},` `"script"``: ``"params.totalSales > 200"` `}` `}` `}` `}` `}` `}` | 以下是响应信息: | `{` `"took"``: ``11``,` `"timed_out"``: ``false``,` `"_shards"``: ...,` `"hits"``: ...,` `"aggregations"``: {` `"sales_per_month"``: {` `"buckets"``: [` `{` `"key_as_string"``: ``"2015/01/01 00:00:00"``,` `"key"``: ``1420070400000``,` `"doc_count"``: ``3``,` `"total_sales"``: {` `"value"``: ``550.0` `}` `},                                            #``1` `{` `"key_as_string"``: ``"2015/03/01 00:00:00"``,` `"key"``: ``1425168000000``,` `"doc_count"``: ``2``,` `"total_sales"``: {` `"value"``: ``375.0` `},` `}` `]` `}` `}` `}` | | 1 | 由于其总销售额不足200,所以2015/02/01 00:00:00 的bucket已被移除 |