Elasticsearch学习之嵌套聚合,下钻分析,聚合分析

1. 计算每个tag下的商品数量

  GET /ecommerce/product/_search
  {
    "aggs": {
      "group_by_tags": {
        "terms": { "field": "tags" }
      }
    }
  }

2. 将文本field的fielddata属性设置为true

  PUT /ecommerce/_mapping/product
  {
    "properties": {
      "tags": {
        "type": "text",
        "fielddata": true
      }
    }
  }

  GET /ecommerce/product/_search
  {
    "size": 0,
      "aggs": {
        "all_tags": {
        "terms": { "field": "tags" }
      }
    }
  }

3. 对名称中包含yagao的商品,计算每个tag下的商品数量

  GET /ecommerce/product/_search
  {
    "size": 0,
    "query": {
      "match": {
        "name": "yagao"
      }
    },
    "aggs": {
      "all_tags": {
        "terms": {
          "field": "tags"
        }
      }
    }
  }

4. 先分组,再算每组的平均值,计算每个tag下的商品的平均价格

  GET /ecommerce/product/_search
  {
    "size": 0,
    "aggs" : {
      "group_by_tags" : {
        "terms" : { "field" : "tags" },
        "aggs" : {
          "avg_price" : {
            "avg" : { "field" : "price" }
          }
        }
      }
    }
  }

5. 计算每个tag下的商品的平均价格,并且按照平均价格降序排序

  GET /ecommerce/product/_search
  {
    "size": 0,
    "aggs" : {
      "all_tags" : {
        "terms" : { "field" : "tags", "order": { "avg_price": "desc" } },
        "aggs" : {
          "avg_price" : {
            "avg" : { "field" : "price" }
          }
        }
      }
    }
  }

6. 按照指定的价格范围区间进行分组,然后在每组内再按照tag进行分组,最后再计算每组的平均价格

  GET /ecommerce/product/_search
  {
    "size": 0,
    "aggs": {
      "group_by_price": {
        "range": {
          "field": "price",
          "ranges": [
            {
              "from": 0,
              "to": 20
            },
            {
              "from": 20,
              "to": 40
            },
            {
              "from": 40,
              "to": 50
            }
          ]
        },
        "aggs": {
          "group_by_tags": {
            "terms": {
              "field": "tags"
            },
          "aggs": {
            "average_price": {
              "avg": {
                  "field": "price"
               }
             }
           }
          }
       }
      }
     }
   }

时间: 2024-12-13 15:24:26

Elasticsearch学习之嵌套聚合,下钻分析,聚合分析的相关文章

Elasticsearch学习之深入聚合分析三---案例实战

1. 统计指定品牌下每个颜色的销量 任何的聚合,都必须在搜索出来的结果数据中进行,搜索结果,就是聚合分析操作的scope GET /tvs/sales/_search { "size": 0, "query": { "term": { "brand": { "value": "小米" } } }, "aggs": { "group_by_color"

es lucene搜索及聚合流程源码分析

本文以TermQuery,GlobalOrdinalsStringTermsAggregator为例,通过代码,分析es,lucene搜索及聚合流程.1:协调节点收到请求后,将search任务发到相关的各个shard. 相关代码: TransportSearchAction.executeSearch TransportSearchAction.searchAsyncAction.start AbstractSearchAsyncAction.executePhase(SearchQueryTh

KeyMob聚合/移动广告聚合平台/选择我们没有错!

移动广告聚合平台通常是指为IOS.Android应用开发者提供广告服务和盈利机会的第三方平台,如艾德聚合.KeyMob聚合.果合.抓猫聚合.它集合多家广告平台的服务并结合自身的数据优化策略,开发者可以同时整合多家的广告资源,帮助开发者实现广告收益的提升. KeyMob是国内一家专业的IOS.Android移动广告聚合平台.有banner.插屏.全屏等多种广告形式,拥有强大的技术支持.优质的广告资源和的稳定的SDK,帮助应用开发者创造更高的收益. KeyMob移动广告聚合平台可以自由切换广告平台,

Atitit 如何设置与安放知识的trap陷阱  知识聚合 rss url聚合工具 以及与trap的对比

Atitit 如何设置与安放知识的trap陷阱  知识聚合 rss url聚合工具 以及与trap的对比 1.1. 安放地点 垂直知识网站csdn cnblogs等特定频道栏目,大牛博客 1 1.2. 如何捕获英文知识 使用推酷等聚合网站..以及到英文站点rss捕获 1 1.3. rss url聚合工具 atiplat_spider 1 1.4. Atiitt捕猎打猎工具---mini陷阱 捕鱼工具trap 瓶子 1 1.5. str(gle sejyi等) 2 1.6. 小河石头搞个ho sh

Accelerated C++学习笔记7—<使用顺序容器并分析字符串>

第6章  使用库算法 本章中主要教我们如何使用几个库算法来解决与处理字符串和学生成绩相关的问题. 1.分析字符串 使用一个循环来连接两幅字符图案 for(vector<string>::const_iterator it = bottom.begin(); it != bottom.end(); ++it) ret.push_back(*it);</span> 等价于 ret.insert(ret.end(), bottom.begin(), bottom.end());</

什么是聚合支付,聚合支付有什么优势

什么是聚合支付,聚合支付有什么优势 聚合支付:也称"融合支付", 聚合支付简单理解就是通过技术服务聚合了各种第三方支付+线下收单等能力的支付方式,目的在于简化商家的接入和统一对账的问题,外加后续的增值服务.极大方便了客户和商户的使用. 聚合支付诞生背景 截至2016年6月,我国使用网上支付的用户规模达到4.55亿,较2015年底增加3857万人,增长率为9.3%,我国网民使用网上支付的比例从60.5%提升至64.1%.手机支付用户规模增长迅速,达到4.24亿,半年增长率为18.7%,网

elasticsearch学习笔记——相关插件

logstash-input-jdbc学习 ES(elasticsearch缩写)的一大优点就是开源,插件众多.所以扩展起来非常的方便,这也造成了它的生态系统越来越强大.这种开源分享的思想真是与天朝格格不入啊.国内的开源社区做了也很长时间,可是也没出现什么拿的出手的东西,可能只还有阿里比较注重分享一些. ES的查询速度非常快,搜索非常快.但是呢,我们的数据还是主要存在传统的关系型数据库中的.有没有什么办法可以将数据库中的数据实时同步到ES中呢.logstash就是这么一个东西. Logstash

ElasticSearch 启动时加载 Analyzer 源码分析

ElasticSearch 启动时加载 Analyzer 源码分析 本文介绍 ElasticSearch启动时如何创建.加载Analyzer,主要的参考资料是Lucene中关于Analyzer官方文档介绍.ElasticSearch6.3.2源码中相关类:AnalysisModule.AnalysisPlugin.AnalyzerProvider.各种Tokenizer类和它们对应的TokenizerFactory.另外还参考了一个具体的基于ElasticSearch采用HanLP进行中文分词的

java代码分析及分析工具

java代码分析及分析工具 一个项目从搭建开始,开发的初期往往思路比较清晰,代码也比较清晰.随着时间的推移,业务越来越复杂.代码也就面临着耦合,冗余,甚至杂乱,到最后谁都不敢碰. 作为一个互联网电子商务网站的业务支撑系统,业务复杂不言而喻.从09年开始一直沿用到现在,中间代码经过了多少人的手,留下了多少的坑,已经记不清楚了,谁也说不清了. 代码的维护成本越来越高.代码已经急需做调整和改善.最近项目组专门设立了一个小组,利用业余时间做代码分析的工作,目标对核心代码进行分析并进行设计重构. 代码分析