4

我试图使用 Searchkick 来运行基于多个模型的搜索和返回。

我的书模型包含这个

class Book < ActiveRecord::Base

  searchkick

  has_many :book_subjects
  has_many :subjects, through: :book_subjects

  belongs_to :author
  belongs_to :publisher

end

然后我的控制器有这个

def index

 if params[:search].present?
   @books = Book.search(params[:search], operator: "or")
 else
  @books = Book.all
 end
end

我希望搜索结果搜索相关模型并在那里返回任何结果——所以是 boo 主题名称、作者和出版商。

谢谢

4

1 回答 1

18

在您的 Book 模型中,您需要有一个search_data用于索引的块。

def search_data
  attributes.merge(
    author_name: author(&:name)
    publisher_name: publisher(&:name)
    subjects_name: subjects.map(&:name)
  )
end

这会将关联添加到您的索引中。

您使用关联的.map方法。has_many

于 2015-06-28T07:43:32.430 回答