栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何过滤Elasticsearch全局聚合?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何过滤Elasticsearch全局聚合?

我认为这是post_filter的典型用例。正如文档所说:

在已经计算出聚合之后,post_filter会在搜索请求的最后应用于搜索匹配

您的查询将如下所示:

{    "post_filter":{       "terms":{ "family_name":"Brown" //filter_1        }    },   "aggs":{        "young_age":{ "filter":{     "range":{ "lt":40, "gt":18 } //filter_2 }, "aggs":{     "age":{         "terms":{  "field":"age"         }     } }        }    }}

在这种情况下,搜索结果是索引中的所有文档。然后计算聚合(在filter_1之前)。然后

post_filter
执行filter_1。

编辑:正如您在表彰中所说,您有很多聚合,而且只有一个不受此影响,

filter_1
我使用全局聚合修复了查询

{  "query": {    "filtered": {      "filter": {        "term": {          "family_name": "Brown"        }      }    }  },  "aggs": {    "young_age": {      "global": {},      "aggs": {        "filter2": {          "filter": { "range": {   "lt": 40,   "gt": 18 }          },          "aggs": { "age": {   "terms": {     "field": "age"   } }          }        }      }    }  }}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/409478.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号