查询包含嵌套数组Elasticsearch中的所有值的文档

时间:2019-08-05 20:03:55

标签: elasticsearch elasticsearch-6 elasticsearch-query

我正在尝试查询嵌套数组包含查询中传递的所有元素的文档。

索引存储组,每个组都有一个成员列表。我想查询包含给定成员的所有组。

映射:

"properties" : {
   "members" : {
      "type" : "nested",
      "properties" : {
         "name" : {
            "type" : "keyword"
         }
       }
    },
    "name" : {
        "type" : "text"
     }
   }
  }
}

示例内容:

[
  {
    "name" : "group 1",
    "members" : [
      {
        "name" : "alice"
      },
      {
        "name" : "bob"
      }
    ]
  },
  {
    "name" : "group 2",
    "members" : [
      {
        "name" : "alice"
      },
      {
        "name" : "foo"
      },
      {
        "name" : "bob"
      }
    ]
  },
  {
    "name" : "group 3",
    "members" : [
      {
        "name" : "foo"
      },
      {
        "name" : "bar"
      }
    ]
  }
]

如何找到同时具有“ alice”和“ foo”作为成员的所有组?

我尝试了以下查询,但未返回任何内容:

GET /group/_search
{
  "query": {
    "nested": {
      "path": "members",
      "query": {
        "bool": {
          "must": [
            {"match": {"members.name": "alice"}},
            {"match": {"members.name": "foo"}}
          ]
        }
      }
    }
  }
}

我也尝试使用term而不是match,但没有任何结果。

1 个答案:

答案 0 :(得分:2)

您可以在must子句中使用嵌套。像这样:

GET /group/_search
{
 "query": {
   "bool": {
     "must": [
       {
         "nested": {
           "path": "members",
           "query": {
             "term": {
               "members.name": {
                 "value": "alice"
               }
             }
           }
         }
       },
       {
         "nested": {
           "path": "members",
           "query": {
             "term": {
               "members.name": {
                 "value": "foo"
               }
             }
           }
         }
       }
     ]
   }
 }
}
相关问题