小笔头有梦想
2020-12-12 10:00
采纳率: 100%
浏览 342
已结题

ES控制台报错提示nested path [params] is not nested无法解决

SpringBoot项目ES搜索正常控制台报错提示nested path [params] is not nested无法解决

Caused by: AggregationExecutionException[[nested] nested path [params] is not nested]
    at org.elasticsearch.search.aggregations.bucket.nested.NestedAggregationBuilder.doBuild(NestedAggregationBuilder.java:88)
    at org.elasticsearch.search.aggregations.AbstractAggregationBuilder.build(AbstractAggregationBuilder.java:126)
    at org.elasticsearch.search.aggregations.AggregatorFactories$Builder.build(AggregatorFactories.java:333)
    at org.elasticsearch.search.SearchService.parseSource(SearchService.java:651)
    at org.elasticsearch.search.SearchService.createContext(SearchService.java:481)
    at org.elasticsearch.search.SearchService.createAndPutContext(SearchService.java:457)
    at org.elasticsearch.search.SearchService.executeQueryPhase(SearchService.java:253)
    at org.elasticsearch.action.search.SearchTransportService$6.messageReceived(SearchTransportService.java:330)
    at org.elasticsearch.action.search.SearchTransportService$6.messageReceived(SearchTransportService.java:327)
    at org.elasticsearch.transport.RequestHandlerRegistry.processMessageReceived(RequestHandlerRegistry.java:69)
    at org.elasticsearch.transport.TransportService$7.doRun(TransportService.java:644)
    at org.elasticsearch.common.util.concurrent.ThreadContext$ContextPreservingAbstractRunnable.doRun(ThreadContext.java:638)
    at org.elasticsearch.common.util.concurrent.AbstractRunnable.run(AbstractRunnable.java:37)
    ... 3 more

已经尝试更换ES版本包括更换依赖的版本,都无法解决该问题

跪求大神知道的帮忙指点一二

  • 好问题 提建议
  • 收藏

4条回答 默认 最新

  • 孟林洁 2020-12-15 11:27
    已采纳

    你在创建索引,指定索引mapping时,需要将该字段指定为"type": "nested"类型,如:"petList": {
            "type": "nested",
            "properties": {
              "birthday": {
                "type": "date"
              },
              "breedId": {
                "type": "long"
              },
              "breedName": {
                "type": "text"
              },
              "gender": {
                "type": "text"
              },
              "id": {
                "type": "long"
              },
              "imgUrl": {
                "type": "text"
              },
              "name": {
                "type": "text",
                "analyzer": "ik_max_word"
              }
            }
          },

    根据此嵌套对象中字段name查询时,使用

    QueryBuilders.nestedQuery("petList", QueryBuilders.matchQuery("petList.name", query), ScoreMode.Total)构建QueryBuilder对象进行查询。
    已采纳该答案
    评论
    解决 无用
    打赏 举报
  • 歇歇 2020-12-12 14:11

    这是因为在创建索引时没有指定类型为数组,这就是一个大坑,ES官方说可以不用指定数字组类型,结果不指定的聚合结果还不一样!!!而且由于一些其他因素,导致不能在创建索引时就指定该字段的类型,可以试试使用动态映射模板勉强解决了。

    评论
    解决 无用
    打赏 举报
  • 小笔头有梦想 2020-12-13 20:43

    我用@Field(type = FieldType.Nested)指定的,结果查询的时候说找不到

    评论
    解决 无用
    打赏 举报
  • 歇歇 2020-12-14 14:31

    动态隐射

    评论
    解决 无用
    打赏 举报

相关推荐 更多相似问题