我有一个模型(下面的简化版本 - 完整版本有很多更多字段)我想在其上进行搜索。
class Media < ActiveRecord::Base
attr_accessible :subject, :title, :ref_code
validates :title, :presence => true
validates :subject, :presence => true
def self.search(terms_hash)
return if terms_hash.blank?
composed_scope = self.scoped
terms_hash.each_pair do |key, value|
if self.respond_to? key and not value.is_blank?
value.split(' ').each do |term|
term = "%#{term}%"
composed_scope = composed_scope.where("#{key} LIKE ?", term)
end
end
composed_scope
end
end
由于高级搜索表单几乎与用于创建/更新模型实例的表单相同,我想创建一个方法,动态查看请求的参数列表,并通过名称将表单字段与模型属性匹配。因此,如果搜索请求是,
/search?utf8=✓&ref_code=111&title=test&subject=code&commit=Search
然后我的控制器可以调用Media.search(params)并返回一个范围,该范围将在适当的字段中搜索适当的值。正如您所看到的,我尝试使用respond_to?
,但仅针对模型实例而不是实际模型类进行定义,我需要忽略与模型无关的任何参数(例如。utf8并在这种情况下提交)。如果一切正常,我计划重构代码,以便我可以为多个模型重用相同的方法。
是否有类似于respond_to?
的类方法?你会怎么做同样的任务?
我知道这与get model attribute dynamically in rails 3有关,但它并没有真正回答我正在尝试做的事情,因为我想在模型上而不是模型的实例。
答案 0 :(得分:5)
ActiveRecord模型类上有columns
method,因此您可以轻松获取属性名称列表:
names = Model.columns.map(&:name)
你可以很容易地删除一些常见的:
names = Model.columns.map(&:name) - %w[id created_at updated_at]
accessible_attributes
类方法也可能会引起关注,它会告诉您attr_accessible
的内容。