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

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对象进行查询。
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 乘性高斯噪声在深度学习网络中的应用
  • ¥15 运筹学排序问题中的在线排序
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥30 求一段fortran代码用IVF编译运行的结果
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥30 python代码,帮调试,帮帮忙吧