• 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"
    							}
    						}
    					}
    				}
    			}
    		}
    	}
    }
    
  • 相关阅读:
    oracle字符集查看修改
    oracle查看所有表及字段
    oracle重新启动步骤
    oracle job 定时执行 存储过程
    oracle导入导出exp,imp
    oracle创建表空间
    Oracle Dataguard HA (主备,灾备)方案部署调试
    Moving Tables-贪心
    Windows下Android开发环境配置
    在单进程单线程或单进程多线程下实现log4cplus写日志并按大小切割
  • 原文地址:https://www.cnblogs.com/shangwei/p/13408220.html
Copyright © 2020-2023  润新知