【发布时间】:2011-01-03 21:42:04
【问题描述】:
我有一个问题。我有一个显示视图,它充当仪表板,并从其他模型中引入记录,然后是与之关联的模型。我有一个简单的搜索表单,可以很好地搜索一个模型,但我不知道如何让它也可以查看其相关模型。我不认为全文搜索是必要的,我不确定它是如何工作的,因为我不想要在整个网站上搜索的东西。
谢谢
公司/节目/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>
士兵.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'"])
【问题讨论】:
-
我认为以下答案是最好的,但以防万一有人感兴趣,这很混乱但也有效:find(:all, :joins => :primaries, :conditions => ['soldiers .email LIKE ? OR primaries.email LIKE ? OR 士兵.名字 LIKE {[search]}%", "%#{[search]}%", "%#{[search]}%", "%#{[search]}%", "%#{[search]}% "], :order => 'soldiers.lastname')
标签: ruby-on-rails search forms