Elasticsearch学习笔记2----聚合操作及常见问题解决
来源:互联网 发布:未来清单软件下载 编辑:程序博客网 时间:2024/06/06 01:48
"terms" : { " field": "" }分组
"avg" : { "field" : "price" }求平均值
"order": { "avg_price": "desc" }排序
最后一个案例是按范围分组
第一个分析需求:计算每个tag下的商品数量(根据tag分组)
GET /ecommerce/product/_search
{
"aggs": {
"group_by_tags": {
"terms": { "field": "tags" }
}
}
}
发现报错
"error": {
"root_cause": [
{
"type": "illegal_argument_exception",
"reason": "Fielddata is disabled on text fields by default. Set fielddata=true on [tags] in order to load fielddata in memory by uninverting the inverted index. Note that this can however use significant memory."
}
],
解决:将文本field的fielddata属性设置为true
PUT /ecommerce/_mapping/product
{
"properties": {
"tags": {
"type": "text",
"fielddata": true
}
}
}
再重复上面操作就可以了。
第三个聚合分析的需求:先分组,再算每组的平均值,计算每个tag下的商品的平均价格
GET /ecommerce/product/_search
{
"size": 0,
"aggs" : {
"group_by_tags" : {
"terms" : { "field" : "tags" },
"aggs" : {
"avg_price" : {
"avg" : { "field" : "price" }
}
}
}
}
}
----------------------------------------------------------------------------------------------------------------
第四个数据分析需求:计算每个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"
}
}
}
}
}
}
}
}
- Elasticsearch学习笔记2----聚合操作及常见问题解决
- elasticsearch学习笔记--聚合函数篇
- Elasticsearch笔记-聚合
- Elasticsearch常见问题与解决
- Elasticsearch 学习笔记 Elasticsearch及Elasticsearch head安装配置
- Elasticsearch API聚合查询-笔记
- Elasticsearch学习笔记(2)
- ElasticSearch学习笔记-JavaAPI操作记录
- Elasticsearch学习笔记(五)批量操作
- Elasticsearch学习笔记1----常用查询操作
- MySQL学习及常见问题的解决
- Oracle学习及常见问题的解决-day01
- Oracle学习及常见问题的解决-day02
- windows qt学习笔记----vs新建QT工程及常见问题解决(1)
- [Elasticsearch] 聚合的测试数据 2
- Elasticsearch聚合
- Elasticsearch]聚合
- ElasticSearch聚合
- Cannot determine embedded database driver class for database type NONE
- Spring Web应用中文乱码的问题解决办法
- 索引、视图,导入和导出,备份和恢复
- fiddler抓取https请求和jmeter模拟https请求
- 当前不会命中断点 还没有为该文档加载任何符号
- Elasticsearch学习笔记2----聚合操作及常见问题解决
- dpkg:处理 xxx (--configure)时出错解决办法
- 在Ubuntu下如何压缩一个文件夹
- Java中的构造方法总结
- concat函数
- Mac 下配置react-native 安卓环境中遇到的坑
- 动画
- windows版nginx命令
- 201703-4 地铁修建 最短路