2

我正在使用sunspot. 如何运行LIKE查询 ( LIKE %q%)?我想做这样的事情:

 @search = Sunspot.search(User) do |q|
   q.text_fields { with(:company_name).like(params[:q]) }
 end.results

代替:

@search = Sunspot.search(User) do |q|
  q.text_fields { with(:company_name).starting_with(params[:q]) }
end.results

这部分对我有用。查看sunspot代码,我发现了这段代码:

class StartingWith < Base
  private

  def to_solr_conditional
    "#{solr_value(@value)}*"
  end
end

它基本上生成以下太阳黑子搜索哈希:

Sunspot.search(User) do |q| 
  q.text_fields { with(:company_name).starting_with("sta")} }
end

=> Sunspot::Search:{:q=>"*:*", :fq=>["type:User", "company_name_text:sta*"]} 

如果没有更简单的实现方法LIKE %query%,我应该如何使用生成 SOLR 逻辑Like的方法创建一个新类?to_solr_conditional

4

1 回答 1

3

如果您使用标准 DisMax 处理程序,它不支持通配符。您有 2 个选项:

一个。激活 EdgeNgramFilter:

<fieldType name="text" class="solr.TextField" omitNorms="false">
  <analyzer type="index">
    ..
    <filter class="solr.EdgeNGramFilterFactory" minGramSize="2" maxGramSize="15" side="front"/>
    ..
  </analyzer>
</fieldType>

湾。使用EDismax Handler每晚构建 Solr 。

请参阅关于太阳黑子文档的 wiki 文章关于 SO 的类似问题

于 2011-05-19T06:32:26.383 回答