Elasticsearch学习笔记聚合分析Agg

Posted 求知若饥虚心若愚,脚着沃野长望星空,天高海阔水静深流.

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Elasticsearch学习笔记聚合分析Agg相关的知识,希望对你有一定的参考价值。

一、设置fielddata

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

二、聚合分析

1、聚合分析基本语法:


     需求1:计算每个tag下的商品数量
GET /ecommerce/product/_search          // GET /index/type/_search
{
   "size": 0,   // 返回数据hits内不显示命中的数据记录
   "aggs": {
     "all_tags": {  // 聚合器名称
       "AGG_TYPE": {      //AGG_TYPE聚合类型:terms,avg
         "field": "fieldName"//字段名称
       }
     }
   }
}

2、为聚合分析添加刷选条件


     需求2:对名称中包含yagao的商品,计算每个tag下的商品数量

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


3、嵌套聚合分析


     需求3:先分组,再算每组的平均值,计算每个tag下的商品的平均价格

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


4、聚合结果排序


需求4:计算每个tag下的商品的平均价格,并且按照平均价格降序排序
GET /ecommerce/product/_search
{
   "size": 0,
   "aggs": {
     "all_tags": {
       "terms": {
         "field": "tags",
         "order": {
           "avg_price": "asc"
         }
       },
       "aggs": {
         "avg_price": {
           "avg": {
             "field": "price"
           }
         }
       }
     }
   }
}

需求5:按照指定的价格范围区间进行分组,然后在每组内再按照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": {
         "all_tags": {
           "terms": {
             "field": "price"
           },
           "aggs": {
             "avg_price": {
               "avg": {
                 "field": "price"
               }
             }
           }
         }
       }
     }
   }
}

以上是关于Elasticsearch学习笔记聚合分析Agg的主要内容,如果未能解决你的问题,请参考以下文章

ElasticStack学习:ElasticSearch索引模板与聚合分析初探

ElasticSearch 学习笔记总结

elasticsearch系列六:聚合分析(聚合分析简介指标聚合桶聚合)

ElasticSearch聚合分析

elasticsearch的嵌套聚合,下钻分析,聚合分析

4.elasticsearch聚合分析