Elasticsearch: вложенный объект по пути не имеет вложенного типа
Я пытаюсь выполнить поиск по моему документу, содержащему вложенное поле. Я создал вложенное сопоставление следующим образом:
{
"message": {
"properties": {
"messages": {
"type": "nested",
"properties": {
"message_id": { "type": "string" },
"message_text": { "type": "string" },
"message_nick": { "type": "string" }
}
}
}
}
}
Мой поиск выглядит следующим образом:
curl -XGET 'localhost:9200/thread_and_messages/thread/_search' \
-d '{"query": {"bool": {"must": [{"match": {"thread_name": "Banana"}}, {"nested": {"path": "messages", "query": {"bool": {"must": [{"match": {"messages.message_text": "Banana"}}]}}}]}}}}'
Но я получаю это сообщение об ошибке:
QueryParsingException[[thread_and_messages] [nested] nested object under path [messages] is not of nested type]
ИЗМЕНИТЬ
Я все еще получаю эту ошибку. Я делаю это через Java, поэтому это документ, который я пытаюсь создать:
{
"_id": {
"path": "3",
"thread_id": "3",
"thread_name": "Banana",
"created": "Wed Mar 25 2015",
"first_nick": "AdminTech",
"messages": [
{
"message_id": "9",
"message_text": "Banana",
"message_nick": "AdminTech"
}
]
}
}
Создание индекса так:
CreateIndexRequestBuilder indexRequest = client.admin().indices().prepareCreate(INDEX).addMapping("message", mapping);
Я думаю, что я, возможно, неправильно индексировал документ.
Ответы
Ответ 1
TL;DR: Поместите "type": "nested",
в свой вложенный тип.
Скажем, что у нас нормальный тип, и в него вложен другой тип:
{
"some_index": {
"mappings": {
"normal_type": {
"properties": {
"nested_type": {
"type": "nested",
"properties": {
"address": {
"type": "string"
},
"country": {
"type": "string"
}
}
},
"first_name": {
"type": "string"
},
"last_name": {
"type": "string"
}
}
}
}
}
}
Строка "type": "nested",
требуется для работы вложенных запросов, для которых "path":
назначен nested_type
, например:
GET /some_index/normal_type/_search
{
"query": {
"nested": {
"query": {
"bool": {}
},
"path": "nested_type"
}
}
}
Строка "type": "nested",
, по-видимому, требуется только в новых версиях Elasticsearch (начиная с версии 1.1.1?).
Ответ 2
Синтаксическая ошибка в запросе DSL. Неправильное закрытие для блока должен query->bool->must
{
"query": {
"bool": {
"must": [
}// Should be ]
}
}
}
Правильный запрос версии:
curl -XGET 'localhost:9200/thread_and_messages/thread/_search' -d '{
"query": {
"bool": {
"must": [
{
"match": {
"thread_name": "Banana"
}
},
{
"nested": {
"path": "messages",
"query": {
"bool": {
"must": [
{
"match": {
"messages.message_text": "Banana"
}
}
]
}
}
}
}
]
}
}
}'