我正在尝试使用Dismax Query Parser从solr 4.5获取索引数据的自由文本搜索结果,但没有返回结果,并且没有像这样的简单查询的错误:
http://localhost:9999/solr/products/select?q=cuir&qf=text_fr&defType=dismax
这些文件存在于索引中:
{ id: 1, label: "Sac à main en cuir" }
{ id: 2, label: "Sac à main en cuir rouge" }
我的schema.xml是:
..
<field name="id" type="int" indexed="true" stored="true" required="true" />
<field name="label" type="string" indexed="true" stored="true" required="true" />
...
<copyField source="label" dest="label_fr"/>
<dynamicField name="*_fr" type="text_fr" indexed="true" stored="false" />
...
<fieldType name="text_fr" class="solr.TextField" positionIncrementGap="100">
<analyzer>
<tokenizer class="solr.KeywordTokenizerFactory"/>
<filter class="solr.LowerCaseFilterFactory"/>
<filter class="solr.StopFilterFactory" ignoreCase="true" words="stopwords_french.txt" enablePositionIncrements="true" />
<filter class="solr.SnowballPorterFilterFactory" language="French"/>
<filter class="solr.CollationKeyFilterFactory" language="fr" strength="primary" />
</analyzer>
</fieldType>
和solrconfig.xml
...
<requestHandler name="/select" class="solr.SearchHandler">
<lst name="defaults">
<str name="echoParams">explicit</str>
<int name="rows">10</int>
<str name="defType">dismax</str>
</lst>
...
所以任何想法都有什么不对?为什么没有结果?
答案 0 :(得分:2)
KeywordTokenizer将您的整个索引字符串视为单个标记,因此它与单个单词查询不匹配。
相反,您可以尝试使用StandardTokenizerFactory,或WhitespaceTokenizerFactory或WordDelimiterFilter。
答案 1 :(得分:0)
在上面的模式中,您已经定义了字段&#34; label&#34; as&#34; string&#34;它将它视为单个字符串
您应该将fieldType更改为:
<field name="label" type="text_general" indexed="true" stored="true" required="true" />
如上所述,text_general fieldType默认配置了StandardTokenizerFactory。
它会将字段视为文本(或字符串),您可以对其执行全文搜索。
注意:在对特定类别进行分面搜索的情况下,FieldType字符串很好,在这种情况下,必须使用String才能获得更好的结果。或者你可以做一个CopyField。