elasticsearch - ElasticSearch 根据桶长度过滤结果(桶中唯一键的数量)
问题描述
我想写下一个弹性聚合,它仅在其内部存储桶的长度大于 1 时才返回一个键。
"aggs": {
"product_definitions": {
"terms": {
"field": "definition_name",
"size": 200,
"exclude": "NO_MATCH",
"min_doc_count": 5
},
"aggs": {
"product_instances": {
"terms": {
"field": "data_source_name",
"size": 100
}
}
}
}
}
这是我的聚合,它返回:
"aggregations": {
"product_definitions": {
"doc_count_error_upper_bound": 10,
"sum_other_doc_count": 29281,
"buckets": [
{
"key": "DANA ANTRİKOT KG",
"doc_count": 13,
"product_instances": {
"doc_count_error_upper_bound": 0,
"sum_other_doc_count": 0,
"buckets": [
{
"key": "SariyerMarketCom",
"doc_count": 13
}
]
}
},
{
"key": "Keskinoğlu Piliç Salam 700G",
"doc_count": 10,
"product_instances": {
"doc_count_error_upper_bound": 0,
"sum_other_doc_count": 0,
"buckets": [
{
"key": "HappyCenterComTr",
"doc_count": 9
},
{
"key": "SanalMarketComTr",
"doc_count": 1
}
]
}
},
{
"key": "Doğuş Filiz Çayı 1000 G",
"doc_count": 9,
"product_instances": {
"doc_count_error_upper_bound": 0,
"sum_other_doc_count": 0,
"buckets": [
{
"key": "HappyCenterComTr",
"doc_count": 7
},
{
"key": "SanalMarketComTr",
"doc_count": 2
}
]
}
}
]
}
}
仅当产品实例存储桶具有两个以上的键时,我才需要产品定义中的键。在此示例中,它应该只返回 2. 和 3. 键而不是 1. 因为 1. 键的桶只包含 1 个键,即
"buckets": [
{
"key": "SariyerMarketCom",
"doc_count": 13
}
]
解决方案
您可以利用bucket_selector
管道聚合来实现这一点,如下所示:
"aggs": {
"product_definitions": {
"terms": {
"field": "definition_name",
"size": 200,
"exclude": "NO_MATCH",
"min_doc_count": 5
},
"aggs": {
"product_instances": {
"terms": {
"field": "data_source_name",
"size": 100
}
},
"minimum_2": {
"bucket_selector": {
"buckets_path": {
"count": "product_instances._bucket_count"
},
"script": "params.count >= 2"
}
}
}
}
}
推荐阅读
- python - 带有元组的 Line() 宏
- php - 如何使用 add_filter 获取带有 elementor (pro) 联系表单的参考代码?
- python - 我们可以在 python 中检测连接到 USB 集线器的设备吗
- r - 如何使用开始和结束来绑定许多 xlsx 文件
- node.js - 使用邮递员的请求正在工作,但使用浏览器它不起作用(nodejs)
- r - mle 错误:非有限差分值 [1]
- main - 我什么时候必须写 argc 和 argv?
- javascript - iPhone 上的 Safari 仅第一次运行“按类添加的 CSS 动画”
- sql - 使用 POSTGIS 生成 MVT 并排除不同缩放级别的一些几何图形
- sql - 如何将 2 个字符串列(日期和时间)转换为一个时间戳