我正在使用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 逻辑的方法to_solr_conditional
创建一个新的类Like
?
如果使用标准 DisMax 处理程序,则它不支持通配符。您有 2 个选项:
a. 激活 EdgeNGramFilter:
<fieldType name="text" class="solr.TextField" omitNorms="false">
<analyzer type="index">
..
<filter class="solr.EdgeNGramFilterFactory" minGramSize="2" maxGramSize="15" side="front"/>
..
</analyzer>
</fieldType>
b. 使用带有 EDismax 处理程序的夜间构建 Solr。
请参阅有关太阳黑子文档的维基文章或有关SO的类似问题。