Ho cercato di cercare sul mio documento che contiene un campo nidificato. Ho creato la mappatura nidificato in questo modo:Elasticsearch: l'oggetto nidificato sotto il percorso non è di tipo annidato
{
"message": {
"properties": {
"messages": {
"type": "nested",
"properties": {
"message_id": { "type": "string" },
"message_text": { "type": "string" },
"message_nick": { "type": "string" }
}
}
}
}
}
La mia ricerca si presenta così:
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"}}]}}}]}}}}'
Eppure io sto ricevendo questo messaggio di errore:
QueryParsingException[[thread_and_messages] [nested] nested object under path [messages] is not of nested type]
EDIT
Sto ancora ricevendo questo errore. Sto facendo questo tramite Java quindi questo è il documento che sto cercando di creare:
{
"_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"
}
]
}
}
creazione dell'indice in questo modo:
CreateIndexRequestBuilder indexRequest = client.admin().indices().prepareCreate(INDEX).addMapping("message", mapping);
Penso che sto forse l'indicizzazione del documento in modo non corretto.
Ho apportato una modifica al mio post originale poiché sto ancora ricevendo l'errore. –