【问题标题】:Update existing documents with nested fields in Solr在 Solr 中使用嵌套字段更新现有文档
【发布时间】:2023-07-04 23:32:01
【问题描述】:

我有一个已包含文档的索引。希望用嵌套值填充这些文档中的字段。例如;假设我有一个如下所示的文档:

  {
    "id":"9",
    "title":"Example document",
    "description":"Lorem Ipsum ..."
  }

现在,我想做的是添加一个字段,使文档看起来像这样:

  {
    "id":"9",
    "title":"Example document",
    "description":"Lorem Ipsum ..."
    "attributes" : [
     {
         "id": "1",
         "name": "color",
         "value": "red"
     },
     {
          "id": "2",
          "name": "size",
          "value": "20"
     }
    ]
  }

我遇到了How to write nested schema.xml in solr?,我尝试使用此架构并使用“添加”到父字段对新值进行原子更新,但我遇到了一个错误。

以下是更新过程的 XML 示例:

<add>
    <doc>
        <field name="id">9</field>
        <field name="attributes" update="add">
            <field name="id">1</field>
            <field name="name">color/field>
            <field name="value">red</field>
        </field>
    </doc>
</add>

这是错误:

java.lang.NullPointerException
    at org.apache.solr.update.processor.FieldMutatingUpdateProcessor.processAdd(FieldMutatingUpdateProcessor.java:110)

    at org.apache.solr.update.processor.UpdateRequestProcessor.processAdd(UpdateRequestProcessor.java:55)

    at org.apache.solr.update.processor.AbstractDefaultValueUpdateProcessorFactory$DefaultValueUpdateProcessor.processAdd(AbstractDefaultValueUpdateProcessorFactory.java:92)

    at org.apache.solr.handler.loader.XMLLoader.processUpdate(XMLLoader.java:263)

    at org.apache.solr.handler.loader.XMLLoader.load(XMLLoader.java:190)     

    at org.apache.solr.handler.UpdateRequestHandler$1.load(UpdateRequestHandler.java:97)

    at org.apache.solr.handler.ContentStreamHandlerBase.handleRequestBody(ContentStreamHandlerBase.java:82)

    at org.apache.solr.handler.RequestHandlerBase.handleRequest(RequestHandlerBase.java:216)

    at org.apache.solr.core.SolrCore.execute(SolrCore.java:2637)                                                                                                        
    at org.apache.solr.servlet.HttpSolrCall.execute(HttpSolrCall.java:794)   

    at org.apache.solr.servlet.HttpSolrCall.call(HttpSolrCall.java:567)      

    at org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:427)

    at org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:357)

    at org.eclipse.jetty.servlet.FilterHolder.doFilter(FilterHolder.java:201)

    at org.eclipse.jetty.servlet.ServletHandler$Chain.doFilter(ServletHandler.java:1601)

    at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:548)
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:143)
    at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:602)
    at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:127)
    at org.eclipse.jetty.server.handler.ScopedHandler.nextHandle(ScopedHandler.java:235)
    at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:1624)
    at org.eclipse.jetty.server.handler.ScopedHandler.nextHandle(ScopedHandler.java:233)
    at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1435)
    at org.eclipse.jetty.server.handler.ScopedHandler.nextScope(ScopedHandler.java:188)
    at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:501)
    at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:1594)
    at org.eclipse.jetty.server.handler.ScopedHandler.nextScope(ScopedHandler.java:186)
    at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1350)
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:141)
    at org.eclipse.jetty.server.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:191)
    at org.eclipse.jetty.server.handler.InetAccessHandler.handle(InetAccessHandler.java:177)
    at org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java:146)
    at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:127)
    at org.eclipse.jetty.rewrite.handler.RewriteHandler.handle(RewriteHandler.java:322)
    at org.eclipse.jetty.server.handler.gzip.GzipHandler.handle(GzipHandler.java:763)
    at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:127)
    at org.eclipse.jetty.server.Server.handle(Server.java:516)
    at org.eclipse.jetty.server.HttpChannel.lambda$handle$1(HttpChannel.java:388)
    at org.eclipse.jetty.server.HttpChannel.dispatch(HttpChannel.java:633)
    at org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:380)
    at org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:277)
    at org.eclipse.jetty.io.AbstractConnection$ReadCallback.succeeded(AbstractConnection.java:311)
    at org.eclipse.jetty.io.FillInterest.fillable(FillInterest.java:105)
    at org.eclipse.jetty.io.ChannelEndPoint$1.run(ChannelEndPoint.java:104)
    at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.runTask(EatWhatYouKill.java:336)
    at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.doProduce(EatWhatYouKill.java:313)
    at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.tryProduce(EatWhatYouKill.java:171)
    at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.run(EatWhatYouKill.java:129)
    at org.eclipse.jetty.util.thread.ReservedThreadExecutor$ReservedThread.run(ReservedThreadExecutor.java:383)
    at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:882)
    at org.eclipse.jetty.util.thread.QueuedThreadPool$Runner.run(QueuedThreadPool.java:1036)

那么,我做错了什么?

【问题讨论】:

    标签: solr


    【解决方案1】:

    应该是这样的

      {
            "id":"9",
            "attributes" :{"add": [
             {
                 "id": "1",
                 "name": "color",
                 "value": "red"
             },
             {
                  "id": "2",
                  "name": "size",
                  "value": "20"
             }
            ]
           }
       }
    

    【讨论】:

      最近更新 更多