我刚刚设置了sunspot_rails,除了一件事情之外它似乎运作良好。 之后我做了3条记录,如下面
当我使用关键字“John”搜索时,只显示第一条记录。它看起来像完全匹配。 我希望所有这些都作为搜索结果出现。
这应该是默认发生的吗? 还是我设置错了?
答案 0 :(得分:8)
如果您想在全文搜索中返回子字符串,可以查看
https://github.com/sunspot/sunspot/wiki/Matching-substrings-in-fulltext-search
此外,您可以在myapp / config / initializers /中添加文件sunspot_solr.rb
以便对结果进行分页:
Sunspot.config.pagination.default_per_page = 100
为此案例返回100个结果。
添加了:
您的schema.xml
文件位于yourappfolder/solr/conf
此外,您可以添加<filter class="solr.NGramFilterFactory"/>
以匹配任意子字符串。
这是我对schema.xml的特定配置:
<fieldType name="text" class="solr.TextField" omitNorms="false">
<analyzer>
<tokenizer class="solr.StandardTokenizerFactory"/>
<filter class="solr.StandardFilterFactory"/>
<filter class="solr.LowerCaseFilterFactory"/>
</analyzer>
</fieldType>
<fieldtype class="solr.TextField" name="text_pre" positionIncrementGap="100">
<analyzer type="index">
<tokenizer class="solr.WhitespaceTokenizerFactory"/>
<filter class="solr.LowerCaseFilterFactory"/>
<filter class="solr.NGramFilterFactory" minGramSize="2" maxGramSize="10"/>
<filter class="solr.ISOLatin1AccentFilterFactory"/>
<filter class="solr.TrimFilterFactory" />
<filter class="solr.EdgeNGramFilterFactory" minGramSize="2" maxGramSize="10"/>
</analyzer>
<analyzer type="query">
<tokenizer class="solr.WhitespaceTokenizerFactory"/>
<filter class="solr.LowerCaseFilterFactory"/>
<filter class="solr.ISOLatin1AccentFilterFactory"/>
<filter class="solr.TrimFilterFactory" />
</analyzer>
</fieldtype>
对我而言,它对所有关键字的完整字符串和子字符串都可以正常工作。请不要忘记重新启动服务器并重新索引模型以使更改生效。
问候!
答案 1 :(得分:0)
感谢!!!
阻止女孩控制器(girls_controller.rb)
def index
@search = Girl.search do
fulltext params[:search]
end
@girls = @search.results
# @girls = Girl.all
#
# respond_to do |format|
# format.html # index.html.erb
# format.json { render json: @girls }
# end
end
阻止来自女模特(girl.rb)
searchable do
text :name_en, :name_es, name_ja
end