apache solr响应中的字段在它们应该是单数时是多值的

Sam*_*m P 6 apache django solr django-haystack solr-multy-valued-fields

我遇到了Apache Solr的问题,我在JSON响应中接收包含在列表中的字段,但它们应该是单数的.下面是一个schema.xml中exerpt,两个示例领域给了我一个问题,是django_ctdjango_id:

  <fields>
    <!-- general -->
    <field name="id" type="string" indexed="true" stored="true" multiValued="false" required="true"/>
    <field name="django_ct" type="string" indexed="true" stored="true" multiValued="false"/>
    <field name="django_id" type="string" indexed="true" stored="true" multiValued="false"/>
Run Code Online (Sandbox Code Playgroud)

以下是如何将数据发布到Solr的示例:

<doc>
    <field name="id">search.productcategory.3</field>
    <field name="gender">M</field>
    <field name="name">OBQYHSOQLWOUEHRMPSDI</field>
    <field name="text">M\nOBQYHSOQLWOUEHRMPSDI</field>
    <field name="django_id">3</field>
    <field name="django_ct">search.productcategory</field>
</doc>
Run Code Online (Sandbox Code Playgroud)

以下是存储在solr中的文件示例:

  "response": {
    "numFound": 1,
    "start": 0,
    "docs": [
      {
        "django_ct": [
          "search.productcategory"
        ],
        "name": [
          "Example"
        ],
        "text": [
          "Male\nExample"
        ],
        "id": "search.productcategory.2",
        "gender": [
          "Male"
        ],
        "django_id": [
          2
        ],
        "_version_": 1502081283634757600
      }
    ]
  }
Run Code Online (Sandbox Code Playgroud)

是什么导致这些字段被包装在列表中?在架构中,multiValued这些字段的属性设置为false.除了创建核心和替换schema.xml之外,其他所有内容都是开箱即用的.我正在使用Haystack(一个Django插件)访问Solr,代码期望接收这些字段的单个值,但完全被它破坏了.追溯问题似乎是由于Solr的配置方式.

编辑:以下是solr.log的完整内容,所有这些都是在启动服务器后记录的,运行几个示例查询没有输出:

INFO  - 2015-05-27 08:38:12.563; [   ] org.eclipse.jetty.server.Server; jetty-8.1.10.v20130312
INFO  - 2015-05-27 08:38:12.586; [   ] org.eclipse.jetty.deploy.providers.ScanningAppProvider; Deployment monitor /Users/sampeka/solr-5.1.0/server/contexts at interval 0
INFO  - 2015-05-27 08:38:12.593; [   ] org.eclipse.jetty.deploy.DeploymentManager; Deployable added: /Users/sampeka/solr-5.1.0/server/contexts/solr-jetty-context.xml
INFO  - 2015-05-27 08:38:13.629; [   ] org.eclipse.jetty.webapp.StandardDescriptorProcessor; NO JSP Support for /solr, did not find org.apache.jasper.servlet.JspServlet
INFO  - 2015-05-27 08:38:13.682; [   ] org.apache.solr.servlet.SolrDispatchFilter; SolrDispatchFilter.init()WebAppClassLoader=1121453612@42d8062c
Run Code Online (Sandbox Code Playgroud)

Sam*_*m P 9

找到了问题的根源.问题是solrconfig.xml没有正确配置.默认情况下,schemafactory该类设置为ManagedIndexSchemaFactory覆盖使用的类schema.xml.通过更改schemaFactoryto类,ClassicIndexSchemaFactory它强制使用 schema.xml并通过API调用使模式不可变.