课程大纲

    1. GET /tvs/_search
    2. {
    3. "size" : 0,
    4. "aggs": {
    5. "colors": {
    6. "terms": {
    7. "field": "color"
    8. },
    9. "aggs": {
    10. "avg_price": {
    11. "avg": {
    12. "field": "price"
    13. }
    14. }
    15. }
    16. }
    17. }
    18. }

    按照color去分bucket,可以拿到每个color bucket中的数量,这个仅仅只是一个bucket操作,doc_count其实只是esbucket操作默认执行的一个内置metric
    这一讲,就是除了bucket操作,分组,还要对每个bucket执行一个metric聚合统计操作
    在一个aggs执行的bucket操作(terms),平级的json结构下,再加一个aggs,这个第二个aggs内部,同样取个名字,执行一个metric操作,avg,对之前的每个bucket中的数据的指定的fieldprice field,求一个平均值

    "aggs": { 
       "avg_price": { 
          "avg": {
             "field": "price" 
          }
       }
    }
    

    就是一个metric,就是一个对一个bucket分组操作之后,对每bucket都要执行的一个metric
    第一个metricavg,求指定字段的平均值

    {
      "took": 28,
      "timed_out": false,
      "_shards": {
        "total": 5,
        "successful": 5,
        "failed": 0
      },
      "hits": {
        "total": 8,
        "max_score": 0,
        "hits": []
      },
      "aggregations": {
        "group_by_color": {
          "doc_count_error_upper_bound": 0,
          "sum_other_doc_count": 0,
          "buckets": [
            {
              "key": "红色",
              "doc_count": 4,
              "avg_price": {
                "value": 3250
              }
            },
            {
              "key": "绿色",
              "doc_count": 2,
              "avg_price": {
                "value": 2100
              }
            },
            {
              "key": "蓝色",
              "doc_count": 2,
              "avg_price": {
                "value": 2000
              }
            }
          ]
        }
      }
    }
    

    buckets,除了keydoc_count
    avg_price:我们自己取的metric aggs的名字
    value:我们的metric计算的结果,每个bucket中的数据的price字段求平均值后的结果

    select avg(price)
    from tvs.sales
    group by color