当前位置: 首页 > news >正文

ElastaticSearch -- es之Filters aggregation 先过滤再聚合

使用场景

使用es时,有时我们需要先过滤后再聚合,但如果直接在query的filter中过滤,不止会影响到一个聚合,还会影响到其他的聚合结果。
比如,我们想要统计深圳市某个品牌的总销售额,以及该品牌的女款衣服的销售额。
直接filter过滤款式为女,那么就无法统计总销售额了。
这时可以使用Filters aggregation。也就是在aggregations中先过滤后再聚合。

Filters aggregation格式


{"size" : 0,"aggregations" : {"自已命名的聚合名称1" : {"filter" : {"bool" : {"filter" : [{"term" : {"查询字段1" : {"value" : 查询值1,"boost" : 1.0}}}]}},"aggregations" : {"自已命名的聚合名称2" : {"sum" : {"field" : "查询值2"}}}}}
} 

示例如下:


{"size" : 0,"query" : {"bool" : {"filter" : ["term" : {"area" : {"value" : "深圳市","boost" : 1.0}}]}},"aggregations" : {"filterAggGirl" : {"filter" : {"bool" : {"filter" : [{"term" : {"type" : {"value" : "女","boost" : 1.0}}}]}},"aggregations" : {"aggAmount" : {"sum" : {"field" : "amount"}}}}}
} 

参考资料:

https://www.elastic.co/guide/en/elasticsearch/reference/7.17/search-aggregations-bucket-filters-aggregation.html

http://www.lryc.cn/news/227753.html

相关文章:

  • 如何把一个接口设计好?
  • mini-vue 的设计
  • React整理杂记(一)
  • [100天算法】-统计封闭岛屿的数目(day 74)
  • esp32-rust-std-examples-blinky
  • 【docker容器技术与K8s】
  • RT-DTER 引入用于低分辨率图像和小物体的新 CNN 模块 SPD-Conv
  • Folw + Room 实现自动观察数据库的刷新
  • 黑马程序员微服务Docker实用篇
  • 虚拟化服务器+华为防火墙+kiwi_syslog访问留痕
  • FlinkSQL聚合函数(Aggregate Function)详解
  • TensorFlow学习笔记--(3)张量的常用运算函数
  • RT-Thread:嵌入式实时操作系统的设计与应用
  • SpringBoot学习笔记-创建菜单与游戏页面(下)
  • STM32一
  • GPT-4 Turbo Assistants API
  • day08_回顾与课程概括
  • iptables、netfilter、firewalld、ufd简单介绍
  • Python基础入门例程53-NP53 前10个偶数(循环语句)
  • v-bind和v-model
  • Adobe premiere裁剪视频尺寸并转为GIF格式
  • 关于react输入框回显问题
  • 案例续集留言板
  • 72 内网安全-域横向CSMSF联动及应急响应初识
  • Leetcode—20.有效的括号【简单】
  • Leetcode—剑指OfferII LCR 019.验证回文串II【简单】
  • Mac电脑配置Flutter开发环境
  • QTableView如何清空数据保留表头
  • [工业自动化-17]:西门子S7-15xxx编程 - 软件编程 - PLC编程语言以及与嵌入式编程的比较
  • 云原生微服务架构及实现技术