ES电商网站商品管理:group by+avg+sort等聚合分析

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

GET /ecommerce/product/_search
{
  "aggs": {     
    "group_by_tags": {    
      "terms": { "field": "tags" }  
    }
  }
}
aggs:聚合
group_by_tags:给聚合取名称
terms:做terms操作,就按照指定的field去进行分组,进行分组以后算出来每个分组里面的document数量。

如果直接操作则会报以下错误,就是需要让你把指定的field的Fielddata属性设置为true。

报错
#将文本field的Fielddata属性设置为true
PUT /ecommerce/_mapping/product
{
  "properties": {
    "tags":{
      "type": "text",
      "fielddata": true
    }
  }
}


继续上面的操作,返回了两部分数据,一部分显示把哪些数据进行了聚合分析,另一部分为聚合操作的结果。如果不想返回操作的数据,加入 "size":0 即可。

#不返回操作的数据
GET /ecommerce/product/_search
{
  "size":0,
  "aggs": {
    "group_by_tags": {
      "terms": {
        "field": "tags"
      }
    }
  }
}
无操作数据的返回值

2. 将名称中包含yagao的商品,计算tag下的商品属性数量(先搜索,再聚合)

GET /ecommerce/product/_search
{
  "size":0,
  "query": {
    "match": {
      "name": "yagao"
    }
  }, 
  "aggs": {
    "group_by_tags": {
      "terms": {
        "field": "tags"
      }
    }
  }
}
#返回值格式与1相同

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

GET /ecommerce/product/_search
{
  "size": 0, 
  "aggs": {
    "group_by_tags_avg": {
      "terms": {
        "field": "tags"
      }
      , "aggs": {
        "group_by_price": {
          "avg": {
            "field": "price"
          }
        }
      }
    }
  }
}
返回值

4. 计算每个tag下的商品属性的平均价格,并且按照平均价格降序排序(先分组,再算出每组平均值,然后排序)

GET /ecommerce/product/_search
{
  "size": 0, 
  "aggs": {
    "group_by_tags": {
      "terms": {
        "field": "tags",
        "order": {
          "group_avg": "desc"
        }
      }
      , "aggs": {
        "group_avg": {
          "avg": {
            "field": "price"
          }
        }
      }
    }
  }
}
返回值

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

GET /ecommerce/product/_search
{
  "size": 0, 
  "aggs": {
    "group_range": {
      "range": {
        "field": "price",
        "ranges": [
          {
            "from": 20,
            "to": 40
          },
          {
            "from": 40,
            "to": 80
          }
        ]
      }
      , "aggs": {
        "group": {
          "terms": {
            "field": "tags"
          }
          , "aggs": {
            "group_avg": {
              "avg": {
                "field": "price"
              }
            }
          }
        }
      }
    }
  }
}
返回值(数据很长只贴出主要的)

你可能感兴趣的:(ES电商网站商品管理:group by+avg+sort等聚合分析)