0

我有一个迷你博客应用程序,我希望用户查看与他们在文章显示页面中阅读的内容相关的文章。如果没有 sunspot_rails gem,我会做这样的事情

在我的模型中

  def self.related_search(query, join = "AND")
    find(:all, :conditions => related_search_conditions(query, join))
  end

  def self.related_search_conditions(query, join)
    query.split(/\s+/).map do |word|
      '(' + %w[name description notes].map { |col| "#{col} LIKE #{sanitize('%' + word.to_s + '%')}" }.join(' OR ') + ')'
    end.join(" #{join} ")
  end

那么在我看来它会是这样的

@article.related_search

但我想使用 sunspot_rails gem 来简化这种方式。任何帮助。谢谢

4

1 回答 1

1

正如 RocketR 所提到的,这是 Sunspot 的一个微不足道的用例。

首先,使用 Sunspot 指定您有三个要作为文本索引的字段。

class Article < ActiveRecord::Base
  searchable do
    text :name
    text :description
    text :notes
  end
end

然后发出搜索,可能来自控制器操作。下面的@search对象包含有关搜索响应的元数据,包括其results方法下的匹配对象。

@search = Article.search do
  keywords query
end
@results = @search.results

要查找与您已加载的对象相似的其他文档,例如在show操作中,您可以调用more_like_this实例方法。这是一种特殊的搜索,它使用了 Solr 的“More Like This”功能,它返回的搜索对象类似于上面的全文搜索。您可以使用它的results方法来呈现该搜索的结果。

<%= render @article.more_like_this.results %>

more_like_this方法还接受与搜索块具有相似选项的块,因此您可以更好地控制判断相似性的方式。

希望有帮助!

于 2011-08-19T08:04:51.110 回答