Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/json/15.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/search/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Json 无法获取以停止字开头的Solr查询的结果_Json_Search_Solr_Lucene - Fatal编程技术网

Json 无法获取以停止字开头的Solr查询的结果

Json 无法获取以停止字开头的Solr查询的结果,json,search,solr,lucene,Json,Search,Solr,Lucene,我正在尝试配置允许以停止字开头的查询的平台。 我有以下文件: { "responseHeader":{ "status":0, "QTime":1, "params":{ "indent":"true", "q":"*:*", "wt":"json"}}, "response":{"nu

我正在尝试配置允许以停止字开头的查询的平台。 我有以下文件:

        {
          "responseHeader":{
            "status":0,
            "QTime":1,
            "params":{
              "indent":"true",
              "q":"*:*",
              "wt":"json"}},
          "response":{"numFound":1,"start":0,"docs":[
              {
                "weight_metric":0.3,
                "maximumPowerDraw":9,
                "beamAngle":50,
                "name_de":"German",
                "type":["product"],
                "id":"5dac69a9-7d54-43f9-b815-0a54e519a1f0",
                "name":"Aloa something"
                }]
          }}
有一个名为name的字段,一个用于英语(默认),另一个名为name_de用于德语。 但我无法理解为什么我要进行此查询,因为我可以在结果中看到文档。
而如果我在开始时使用停止词(welcher)执行另一个查询,则无法得到任何结果

虽然我希望两种情况下的第一个查询结果相同。
但是,对于默认语言,它可以正常工作。
这里我复制了schema.xml的一些片段

    <fieldType name="text_en" class="solr.TextField" positionIncrementGap="100">
      <analyzer type="index">
        <tokenizer class="solr.StandardTokenizerFactory"/>
        <!-- in this example, we will only use synonyms at query time
                 <filter class="solr.SynonymFilterFactory" synonyms="index_synonyms.txt" ignoreCase="true" expand="false"/>
        -->
        <!-- Case insensitive stop word removal.
                   add enablePositionIncrements=true in both the index and query
          analyzers to leave a 'gap' for more accurate phrase queries.
        -->
        <filter class="solr.StopFilterFactory" ignoreCase="true" words="stopwords.txt"
                enablePositionIncrements="true"/>
        <filter class="solr.LowerCaseFilterFactory"/>
        <filter class="solr.EnglishPossessiveFilterFactory"/>
        <filter class="solr.KeywordMarkerFilterFactory" protected="protwords.txt"/>
        <!-- Optionally you may want to use this less aggressive stemmer instead of PorterStemFilterFactory:
                     <filter class="solr.EnglishMinimalStemFilterFactory"/>
        -->
        <filter class="solr.PorterStemFilterFactory"/>
      </analyzer>
      <analyzer type="query">
        <tokenizer class="solr.StandardTokenizerFactory"/>
        <filter class="solr.SynonymFilterFactory" synonyms="synonyms.txt" ignoreCase="true" expand="true"/>
        <filter class="solr.StopFilterFactory" ignoreCase="true" words="stopwords.txt"
                enablePositionIncrements="true"/>
        <filter class="solr.LowerCaseFilterFactory"/>
        <filter class="solr.EnglishPossessiveFilterFactory"/>
        <filter class="solr.KeywordMarkerFilterFactory" protected="protwords.txt"/>
        <!-- Optionally you may want to use this less aggressive stemmer instead of PorterStemFilterFactory:
                     <filter class="solr.EnglishMinimalStemFilterFactory"/>
-->
        <filter class="solr.PorterStemFilterFactory"/>
      </analyzer>
    </fieldType>

    <!-- German -->
    <fieldType name="text_de" class="solr.TextField" positionIncrementGap="100">
      <analyzer>
        <tokenizer class="solr.StandardTokenizerFactory"/>
        <filter class="solr.LowerCaseFilterFactory"/>
        <filter class="solr.StopFilterFactory" ignoreCase="true" words="lang/stopwords_de.txt" format="snowball"
                enablePositionIncrements="true"/>
        <filter class="solr.GermanNormalizationFilterFactory"/>
        <!--<filter class="solr.GermanMinimalStemFilterFactory"/>-->

      </analyzer>
    </fieldType>

...

    <field name="name" type="text_en" stored="true" indexed="true"/>
    <field name="name_de" type="text_de" stored="true" indexed="true"/>
...

    <copyField source="*_de" dest="text_de"/>
    <copyField source="name" dest="text"/>

...

<field name="text" type="text_general" stored="false" indexed="true" multiValued="true" termVectors="true"/>
<field name="text_de" type="text_de" stored="false" indexed="true" multiValued="true" termVectors="true"/>


)问题在于查询语法。请参见中的示例。您的查询是:

name_de:welcher German welcher
只有第一个查询项将在名称中搜索。其余查询项将在默认字段(名称)中搜索。您的查询实际上是:

name_de:welcher name:German name:welcher
相反,请尝试:

name_de:(welcher German welcher)

问题在于您的查询语法。请参见中的示例。您的查询是:

name_de:welcher German welcher
只有第一个查询项将在名称中搜索。其余查询项将在默认字段(名称)中搜索。您的查询实际上是:

name_de:welcher name:German name:welcher
相反,请尝试:

name_de:(welcher German welcher)

谢谢你的回复femtoRgon,你知道我是否可以在查询中的其他地方嵌入该语言吗?ie我有法语(name_fr)和德语(name_de)的字段名,而不是总是在字段名(name_de:something)中指定语言,我希望有一个类似q=name:something&language=de的查询。可能吗?最终会有一个像name_de:something这样的查询是一个很好的实践吗?通过分别为不同的语言编制索引,您肯定做了正确的事情。另一种方法是在完全独立的文档中索引不同的语言,并有一个语言代码字段。不过,我看不出你做的有什么不对。谢谢你的回复femtoRgon,你知道我是否可以在查询中的其他地方嵌入该语言吗?ie我有法语(name_fr)和德语(name_de)的字段名,而不是总是在字段名(name_de:something)中指定语言,我希望有一个类似q=name:something&language=de的查询。可能吗?最终会有一个像name_de:something这样的查询是一个很好的实践吗?通过分别为不同的语言编制索引,您肯定做了正确的事情。另一种方法是在完全独立的文档中索引不同的语言,并有一个语言代码字段。不过,我并不认为你所做的有什么不对。