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这样的查询是一个很好的实践吗?通过分别为不同的语言编制索引,您肯定做了正确的事情。另一种方法是在完全独立的文档中索引不同的语言,并有一个语言代码字段。不过,我并不认为你所做的有什么不对。