ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Elasticsearch 顶尖高手(6)--快速入门案例实战:group by + avg + sort等聚合分析(三)

2019-09-14 13:01:41  阅读:258  来源: 互联网

标签:sort 顶尖高手 group tags price field aggs avg


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

GET /ecommerce/product/_search

{

     “aggs”:{

          “group_by_tags”:{

                 “terms”:{“field”:”tags”}

           }

     }

}

image

将文本field的fielddate属性设置为true

PUT /ecommerce/_mapping/product

{

      “properties”:{

            “tags”:{

                “type”:”text”,

                “fielddata”:true

           }

      }

}

image

重新执行分组命令

“size”:0

可以不显示聚合分析数据的信息,只返回聚合分析之后的结果

image


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

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

image

结果一样,因为每个商品name中都包含有yagao

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

GET /ecommerce/product/_search

{

      “size”:0,

      “aggs”:{

            “group_by_tags”:{

                     “terms”:{“fiedd”:”tags”},

                     “aggs”:{

                           “avg_price”:{

                                    “avg”:{“field”:”price”}

                             }

                     }

             }

      }

}

image


4.在3的基础上,按照平均价格进行排序

GET /ecommerce/product/_search

{

      “size”:0,

      “aggs”:{

            “group_by_tags”:{

                     “terms”:{“fiedd”:”tags”,“order”:{“avg_price”:”desc”}},

                     “aggs”:{

                           “avg_price”:{

                                    “avg”:{“field”:”price”}

                             }

                     }

             }

      }

}

image

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": {
         "group_by_tag": {
           "terms": {
             "field": "tags",
             "order": {
               "avg_by_price": "desc"
             }
           },
           "aggs": {
             "avg_by_price": {
               "avg": {
                 "field": "price"
               }
             }
           }
         }
       }
     }
   }
}

image

标签:sort,顶尖高手,group,tags,price,field,aggs,avg
来源: https://www.cnblogs.com/Mr-WangYue/p/11518866.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有