Запрос документов, содержащих все значения во вложенном массиве Elasticsearch

Я пытаюсь запросить документы, в которых вложенный массив содержит все элементы, переданные в запросе.

Индекс хранит группы, и каждая группа имеет список членов. Я хочу запросить все группы, содержащие заданных членов.

Отображение:

"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, но это не дало результатов.


person Wilder Pereira    schedule 05.08.2019    source источник


Ответы (1)


Вы можете использовать предложение, вложенное в предложение 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"
               }
             }
           }
         }
       }
     ]
   }
 }
}
person Nivaldo Neto    schedule 05.08.2019