转自:
【弄nèng - Elasticsearch】DSL入门篇(七)—— Nested类型查询,聚合_司马缸砸缸了-CSDN博客文章目录1. nested query2. nested 对象聚合项目推荐nested类型就是为了解决object类型在对象数组上丢失关联性的问题的,如果将字段设置为nested类型,那个每一个嵌套对象都会被索引为一个 “隐藏的独立文档”。他会为每一个内部对象属性单独索引。如果你需要保留 object 数组中每个对象的内部关系, 则需要使用 nested 类型, 而不是 [object,ob...https://blog.csdn.net/yy756127197/article/details/103258404
nested类型就是为了解决object类型在对象数组上丢失关联性的问题的,如果将字段设置为nested类型,那个每一个嵌套对象都会被索引为一个 “隐藏的独立文档”。他会为每一个内部对象属性单独索引。
如果你需要保留 object 数组中每个对象的内部关系, 则需要使用 nested 类型, 而不是[object,object] 类型.
【1】嵌套查询-nested query
添加nested属性
PUT schools/_mapping/classes
{"properties": {"users": {"type": "nested"}}
}
添加数据
POST schools/classes/11
{"classes_id": 11,"name": "班级11","address": "深圳市福田区福华路11","price": 11.4,"timestamp": 1572573660000,"users" : [{"name" : "SIMA","age" : "11","price" : 13.4},{"name" : "LIYAO","age" : "13","price" : 13.2}]
}
查询(注意把 must放在 filter或constant_score里面,因为filter不计算评分,效率高)
POST schools/classes/_search
{"query": {"nested" : {"path" : "users","query" : {"bool" : {"must" : [{ "match" : {"users.name" : "SIMA"} },{ "range" : {"users.price" : {"gte" : 11,"lte" : 15}} }]}}}}
}
2. nested 对象聚合
POST schools/classes/_search
{"size": 0, "aggs": {"nested": {"nested": {"path": "users"},"aggs": {"amount_avg": {"avg": {"field": "users.price"}}}}}
}