• Elasticsearch-terms


    单层聚合

    {
    	"aggs": {
    		"group_a": {
    			"terms": {
    				"field": "event_type"
    			}
    		}
    	}
    }
    

    双层聚合

    {
    	"aggs": {
    		"group_a": {
    			"terms": {
    				"field": "event_type"
    			},
    			"aggs": {
    				"group_b": {
    					"terms": {
    						"field": "event_level"
    					}
    				}
    			}
    		}
    	}
    }
    
    1. 按照 tags 字段 进行分组
    {
    	"aggs": {
    		"group_by_tag": {
    			"terms": {
    				"field": "tags",
    			}
    		}
    	}
    }
    
    1. 对名称中包含yagao的商品,计算每个tag下的商品数量
    {
    	"query": {
    		"match": {
    			"name": "yagao"
    		}
    	},
    	"aggs": {
    		"all_tags": {
    			"terms": {
    				"field": "tags"
    			}
    		}
    	}
    }
    
    1. 先分组,再算每组的平均值,计算每个tag下的商品的平均价格
    {
    	"aggs": {
    		"group_by_tags": {
    			"terms": {
    				"field": "tags"
    			},
    			"aggs": {
    				"avg_price": {
    					"avg": {
    						"field": "price"
    					}
    				}
    			}
    		}
    	}
    }
    
    1. 计算每个tag下的商品的平均价格,并且按照平均价格降序排序
    {
    	"aggs": {
    		"all_tags": {
    			"terms": {
    				"field": "tags",
    				"order": {
    					"avg_price": "desc"
    				}
    			},
    			"aggs": {
    				"avg_price": {
    					"avg": {
    						"field": "price"
    					}
    				}
    			}
    		}
    	}
    }
    
    1. 按照指定的价格范围区间进行分组,然后在每组内再按照tag进行分组,最后再计算每组的平均价格
    {
    	"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"
    							}
    						}
    					}
    				}
    			}
    		}
    	}
    }
    
  • 相关阅读:
    FreeMarker list指令(3.2)
    FreeMarker if指令(3.1)
    FreeMarker FTL常用指令(3)
    FreeMarker模板文件的组成(2)
    FreeMarker语言概述(1)
    动态执行--获取某数据库某表某些字段的唯一值
    Luogu P3403 跳楼机|同余最短路
    Luogu P1640 [SCOI2010]连续攻击游戏|二分图
    **** **** 黑白球|DP
    **** **** 建筑物|DP
  • 原文地址:https://www.cnblogs.com/shangwei/p/13408220.html
Copyright © 2020-2023  润新知