课程大纲
GET /tvs/_search
{
"size" : 0,
"aggs": {
"colors": {
"terms": {
"field": "color"
},
"aggs": {
"avg_price": {
"avg": {
"field": "price"
}
}
}
}
}
}
按照color
去分bucket
,可以拿到每个color bucket
中的数量,这个仅仅只是一个bucket
操作,doc_count
其实只是es
的bucket
操作默认执行的一个内置metric
这一讲,就是除了bucket
操作,分组,还要对每个bucket
执行一个metric
聚合统计操作
在一个aggs
执行的bucket
操作(terms),平级的json结构下,再加一个aggs
,这个第二个aggs
内部,同样取个名字,执行一个metric
操作,avg
,对之前的每个bucket中的数据的指定的field
,price field
,求一个平均值
"aggs": {
"avg_price": {
"avg": {
"field": "price"
}
}
}
就是一个metric
,就是一个对一个bucket
分组操作之后,对每bucket
都要执行的一个metric
第一个metric
,avg
,求指定字段的平均值
{
"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
,除了key
和doc_count
avg_price
:我们自己取的metric aggs
的名字value
:我们的metric
计算的结果,每个bucket
中的数据的price
字段求平均值后的结果
select avg(price)
from tvs.sales
group by color