Fork me on GitHub

elasticsearch学习第四弹:聚合案例

计算每个tag下的商品数量

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

1
2
3
4
5
6
7
8
9
PUT /ecommerce/_mapping
{
"properties": {
"tags": {
"type": "text",
"fielddata": true
}
}
}

1
2
3
4
5
6
7
8
GET /ecommerce/_search
{
"aggs": {
"group_by_tags": {
"terms": { "field": "tags" }
}
}
}

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
GET /ecommerce/_search
{
"size": 0,
"query": {
"match": {
"name": "yagao"
}
},
"aggs": {
"all_tags": {
"terms": {
"field": "tags"
}
}
}
}

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
GET /ecommerce/_search
{
"size": 0,
"aggs" : {
"group_by_tags" : {
"terms" : { "field" : "tags" },
"aggs" : {
"avg_price" : {
"avg" : { "field" : "price" }
}
}
}
}
}

计算每个tag下的商品的平均价格,并且按照平均价格降序排序

1
2
3
4
5
6
7
8
9
10
11
12
13
14
GET /ecommerce/_search
{
"size": 0,
"aggs" : {
"all_tags" : {
"terms" : { "field" : "tags", "order": { "avg_price": "desc" } },
"aggs" : {
"avg_price" : {
"avg" : { "field" : "price" }
}
}
}
}
}

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
GET /ecommerce/_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"
}
}
}
}
}
}
}
}

本文标题:elasticsearch学习第四弹:聚合案例

文章作者:tang

发布时间:2019年04月25日 - 18:04

最后更新:2019年04月25日 - 18:04

原始链接:https://tgluon.github.io/2019/04/25/elasticsearch学习第四弹:聚合案例/

许可协议: 署名-非商业性使用-禁止演绎 4.0 国际 转载请保留原文链接及作者。

-------------本文结束感谢您的阅读-------------