Поиск Rails на нескольких моделях - PullRequest
9 голосов
/ 11 января 2010

У меня есть проблема. У меня есть представление шоу, которое выступает в качестве инструментальной панели и приносит записи из других моделей, а затем моделей, связанных с этим. У меня есть простая форма поиска, которая отлично работает для поиска по одной модели, но я не знаю, как заставить ее просматривать и связанные с ней модели. Я не думаю, что полнотекстовый поиск необходим, и я не уверен, как он будет работать, потому что я не хочу что-то, что будет искать по всему сайту.

Спасибо

компании / шоу / 1

<div id="form">
  <div class="search">
   <% form_tag battalion_company_path, :method => :get do %>
   <p>
   <%= text_field_tag :search, params[:search] %>

   <%= submit_tag "Search", :name => nil %>

   </p>
 <% end %>
</div>
</div>

<div id="bc_box">
<% @soldiers.each do |soldier| %>
<div id="bc_focus">
   <div class="right">
    <%= link_to image_tag("../images/buttons/info.png", :border=>0),  battalion_company_soldier_path(@battalion, @company,soldier) %>
    <%= link_to image_tag("../images/buttons/edit.png", :border=>0), edit_battalion_company_soldier_path(@battalion, @company,soldier) %>
    </div>
   <%=h soldier.rank %> <%=h soldier.lastname %><br />
   Cell: <%=h soldier.cellphone %><br />
   <% soldier.primaries.each do |primary| %>
   <p>
   <%=h primary.firstname %> <%=h primary.lastname %> (<%=h primary.relationship %>)<br />

   (c):<%=h primary.cellphone %><br />
   <%=h primary.email %><br />
   </p>
    <% end %>

</div>
  <% end %>
</div>

soldier.rb

def self.search(search)
  if search
    find(:all, :conditions => ['email LIKE ? OR lastname LIKE ? OR firstname LIKE ?', "%#{search}%", "%#{search}%", "%#{search}%"])
  else
    find(:all, :order => 'lastname')
  end
end

companies_controller

@soldiers = @company.soldiers.search(params[:search])
@primary = @company.primaries.find(:all,:conditions => ["relationship = 'Spouse'"])

1 Ответ

4 голосов
/ 11 января 2010

Как насчет поисковой системы вашего приложения, такой как Thinking Sphinx ? Оставьте тяжелую работу по кешированию и поиску кому-то еще, и пусть ваше приложение Rails даст результат.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...