首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Elasticsearch顶级聚合/搜索正文元数据

Elasticsearch顶级聚合/搜索正文元数据
EN

Stack Overflow用户
提问于 2020-07-17 02:47:01
回答 1查看 125关注 0票数 1

可以像这样包含子聚合metadata

代码语言:javascript
复制
GET kibana_sample_data_flights/_search
{
  "size": 0,
  "query": ...,
  "aggs": {
    "by_delay": {
      "terms": {
        "field": "FlightDelay"
      },
      "meta": {                <---
        "key": "val"
      }
    },
    "by_cancelled": {
      "terms": {
        "field": "Cancelled"
      },
      "meta": {                <---
        "key": "val"
      }
    }
  }
}

现在,有几十个这样的子aggs和一些共享元数据。虽然它只适用于aggs,但我不介意将它放在query部分的某个地方。那么有没有每个搜索体的元数据字段呢?

我在想,我可以将所有这些子aggs封装在一个match_all过滤器组中:

代码语言:javascript
复制
{
  "size": 0,
  "query": ...,
  "aggs": {
    "meta_parent": {
      "filter": {
        "match_all": {}
      },
      "meta": {
        "shared": "meta"
      },
      "aggs": {
        "by_delay": ...,
        "by_cancelled": ...
      }
    }
  }
}

有没有更好的方法?

EN

回答 1

Stack Overflow用户

发布于 2020-07-20 11:46:29

如果您没有任何query部件,我可以利用global aggregation,如下所示:

代码语言:javascript
复制
{
  "size": 0,
  "aggs": {
    "meta_parent": {
      "global": {},
      "meta": {
        "shared": "meta"
      },
      "aggs": {
        "by_delay": ...,
        "by_cancelled": ...
      }
    }
  }
}

否则,您对filter/match_all聚合的建议也可以起作用:

代码语言:javascript
复制
{
  "size": 0,
  "aggs": {
    "meta_parent": {
      "filter": {
        "match_all": {}
      },
      "meta": {
        "shared": "meta"
      },
      "aggs": {
        "by_delay": ...,
        "by_cancelled": ...
      }
    }
  }
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62941595

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档