你如何启用与“太阳黑子铁路”部分匹配?

时间:2012-06-23 05:51:40

标签: ruby-on-rails sunspot-rails

我刚刚设置了sunspot_rails,除了一件事情之外它似乎运作良好。 之后我做了3条记录,如下面

  1. 名=约翰
  2. 名= John2
  3. 名= John3
  4. 当我使用关键字“John”搜索时,只显示第一条记录。它看起来像完全匹配。 我希望所有这些都作为搜索结果出现。

    这应该是默认发生的吗? 还是我设置错了?

2 个答案:

答案 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