使用ferret在工程里添加了全文搜索功能。给Model添加了如下代码:
# 全文检索
acts_as_ferret({:fields=>{
:title=>{
:store=>:yes
},
:content=>{
:store=>:yes
}
}},:analyzer=>RMMSeg::Ferret::Analyzer.new)
RMMSeg默认的Analyzer没有做大小写过滤,你可以配合RMMSeg::Ferret::Tokenizer和Ferret的LowerCaseFilter自己写一个,这个是我们JavaEye用的:
[code="ruby"] class JavaEyeAnalyzer
def initialize
@stop_words = []
File.open("#{RAILS_ROOT}/dic/stopwords.dic") do |f| f.each_line { |line| @stop_words << line.chomp.freeze } end
end
def token_stream(field, text)
Ferret::Analysis::StopFilter.new(Ferret::Analysis::LowerCaseFilter.new(RMMSeg::Ferret::Tokenizer.new(text)), @stop_words)
end
end[/code]