【发布时间】:2011-01-31 07:38:30
【问题描述】:
我正在尝试实现高级搜索。
我在模型中有这个:
def self.filter(params)
params.inject(self) do |scope, (key, value)|
return scope if value.blank?
case key
when :min_size
scope.scoped(:conditions => ["size >= ?", value])
when :max_size
scope.scoped(:conditions => ["size <= ?", value])
else
scope.scoped(:conditions => ["created_at > ?", 4.weeks.ago])
end
end
end
这是在我的控制器中:
def search
@listings = Listing.filter(params)
respond_to (:html)
end
我用这个表格搜索:
<%= form_tag '/search', :method => "get" do |f| %>
<%= text_field_tag :min_size, params[:min_size] %>
<%= text_field_tag :max_size, params[:max_size] %>
<%= submit_tag "Search", :name => nil %>
<% end %>
当我尝试搜索时,Rails 似乎忽略了所有传递的参数,并找到了最后一个 case 开关(“created_at > ?”,4.weeks.ago)的所有条目。但是,参数确实通过了:
Started GET "/search?utf8=%E2%9C%93&min_rent=10&max_rent=35" for 127.0.0.1 at Mon Jan 31 12:25:40 +0500 2011
Processing by ListingsController#search as HTML
Parameters: {"utf8"=>"✓", "min_size"=>"40", "max_size"=>"50"}
Listing Load (1.1ms) SELECT "listings".* FROM "listings" WHERE (created_at > '2011-01-03 07:25:40.978742') AND (created_at > '2011-01-03 07:25:40.980977') AND (created_at > '2011-01-03 07:25:40.982080') AND (created_at > '2011-01-03 07:25:40.983077') AND (created_at > '2011-01-03 07:25:40.984138')
这里可能有什么问题?在控制台中它工作得很好
>> some = Listing.filter(:min_size => 40, :max_size => 50)
=> [#<Listing id: 1, title: "1 br apartment, Paris 16e", address: "1 Rue Monsieur-le-Prince", district: "Paris 6e", size: 42, rent: 2000, created_at: "2011-01-26 18:30:57", updated_at: "2011-01-26 19:00:44">]
【问题讨论】:
标签: ruby-on-rails activerecord