zoukankan      html  css  js  c++  java
  • ElasticSearch 嵌套聚合+下钻分析+聚合分析

    第一个分析需求:计算每个tag下的商品数量

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

    将文本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" }
    }
    }
    }

    {
    "took": 20,
    "timed_out": false,
    "_shards": {
    "total": 5,
    "successful": 5,
    "failed": 0
    },
    "hits": {
    "total": 4,
    "max_score": 0,
    "hits": []
    },
    "aggregations": {
    "group_by_tags": {
    "doc_count_error_upper_bound": 0,
    "sum_other_doc_count": 0,
    "buckets": [
    {
    "key": "fangzhu",
    "doc_count": 2
    },
    {
    "key": "meibai",
    "doc_count": 2
    },
    {
    "key": "qingxin",
    "doc_count": 1
    }
    ]
    }
    }
    }

    ----------------------------------------------------------------------------------------------------------------

    第二个聚合分析的需求:对名称中包含yagao的商品,计算每个tag下的商品数量

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

    ----------------------------------------------------------------------------------------------------------------

    第三个聚合分析的需求:先分组,再算每组的平均值,计算每个tag下的商品的平均价格

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

    {
    "took": 8,
    "timed_out": false,
    "_shards": {
    "total": 5,
    "successful": 5,
    "failed": 0
    },
    "hits": {
    "total": 4,
    "max_score": 0,
    "hits": []
    },
    "aggregations": {
    "group_by_tags": {
    "doc_count_error_upper_bound": 0,
    "sum_other_doc_count": 0,
    "buckets": [
    {
    "key": "fangzhu",
    "doc_count": 2,
    "avg_price": {
    "value": 27.5
    }
    },
    {
    "key": "meibai",
    "doc_count": 2,
    "avg_price": {
    "value": 40
    }
    },
    {
    "key": "qingxin",
    "doc_count": 1,
    "avg_price": {
    "value": 40
    }
    }
    ]
    }
    }
    }

    ----------------------------------------------------------------------------------------------------------------

    第四个数据分析需求:计算每个tag下的商品的平均价格,并且按照平均价格降序排序

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

     

    ----------------------------------------------------------------------------------------------------------------

    第五个数据分析需求:按照指定的价格范围区间进行分组,然后在每组内再按照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"
    }
    }
    }
    }
    }
    }
    }
    }

  • 相关阅读:
    I firmly believe
    深度学习常见的专业术语
    阿里、网易和腾讯面试题 C/C++
    Winfrom中关于toolStrip工具栏中按钮背景的设置
    非常完善的Log4net详细说明
    C#中 Var关键字
    C#中Dynamic关键字
    Python中threading的join和setDaemon的区别[带例子]
    pycharm常用快捷键
    ABP发布到iis
  • 原文地址:https://www.cnblogs.com/Transkai/p/11088818.html
Copyright © 2011-2022 走看看