转:elasticsearch nested嵌套查询

Posted PacosonSWJTU

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了转:elasticsearch nested嵌套查询相关的知识,希望对你有一定的参考价值。

转自:

【弄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"
          }
        }
      }
    }
  }
}

以上是关于转:elasticsearch nested嵌套查询的主要内容,如果未能解决你的问题,请参考以下文章

[ElasticSearch]ES操作之嵌套查询(nested)与退出嵌套(reverse_nested)操作

elasticsearch的嵌套查询nested

Elasticsearch es nested 嵌套类型 详解

如何将单个 .NET 类型映射到 ElasticSearch/NEST 中的多个嵌套对象类型?

Elasticsearch 7.x Nested 嵌套类型查询 ES 干货

从 NEST C# 嵌套聚合中获取 Elasticsearch 结果