5 votes

elasticsearch : Nested Document Mapping ne fonctionne pas

J'ai la structure json suivante dans elastic search qui est stockée @ http://localhost:9200/mongoindex/documents/ :

{
"text" : "OTesting1"
"otag" : "otag1"
"pages" : [{
      "text" : "1"
  "name" : "itag1"

    }, {
     "text" : "2"
     "name" : "itag2"
    }
]
}

J'ai créé un mapping imbriqué comme suit pour activer la recherche imbriquée et le filtre imbriqué sur celui-ci :

http://localhost:9200/mongoindex/documents/_mapping [PUT]

{
  "documents": {
    "properties": {
      "pages": {
        "type": "nested"
      }
    }
  }
}

Maintenant, exécutez le code java suivant :

Settings settings = ImmutableSettings.settingsBuilder()
                .put("cluster.name", "xyz").build();
        Client client = new TransportClient(settings).addTransportAddress(new InetSocketTransportAddress("localhost", 9300));
        SearchResponse response = client.prepareSearch("mongoindex")
                .setTypes("documents")
                .setQuery(QueryBuilders.nestedQuery("documents", QueryBuilders.boolQuery().must(QueryBuilders.matchQuery("pages.text", "1"))).scoreMode("avg"))
                .execute()
                .actionGet();

mais il me donne l'exception suivante :

> Exception in thread "main"
> org.elasticsearch.action.search.SearchPhaseExecutionException: Failed
> to execute phase [query], total failure; shardFailures
> {[kSKaBxjGTMSS352kukrYVw][mongoindex][0]:
> SearchParseException[[mongoindex][0]: from[-1],size[-1]: Parse Failure
> [Failed to parse source
> [{"query":{"nested":{"query":{"bool":{"must":{"match":{"pages.text":{"query":"1","type":"boolean"}}}}},"path":"documents","score_mode":"avg"}}}]]];
> nested: QueryParsingException[[mongoindex] [nested] nested object
> under path [documents] is not of nested type];
> }{[kSKaBxjGTMSS352kukrYVw][mongoindex][4]:
> SearchParseException[[mongoindex][4]: from[-1],size[-1]: Parse Failure
> [Failed to parse source
> [{"query":{"nested":{"query":{"bool":{"must":{"match":{"pages.text":{"query":"1","type":"boolean"}}}}},"path":"documents","score_mode":"avg"}}}]]];
> nested: QueryParsingException[[mongoindex] [nested] nested object
> under path [documents] is not of nested type]; }

2voto

Zach Points 4033

Vous devez spécifier le chemin d'accès à votre objet imbriqué dans la balise Requête imbriquée dans votre cas "path" : "pages" . Je ne suis pas familier avec la syntaxe Java, mais la requête REST équivalente ressemblerait à ceci :

{
   "nested" : {
       "path" : "pages",
       "score_mode" : "avg",
       "query" : {
           "bool" : {
               "must" : [
                   {
                       "match" : {"pages.text" : "1"}
                   }
               ]
           }
       }
   }

}

La dernière ligne des messages d'erreur d'ElasticSearch contient généralement les informations nécessaires au débogage (alors que le reste est plutôt inutile et/ou répétitif). C'est donc la partie essentielle :

QueryParsingException[[mongoindex] [nested] objet imbriqué sous le chemin d'accès [documents] n'est pas de type imbriqué] ; }.

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X