我正在努力寻找对动态方法进行元编程的最佳方法,我将根据条件限制结果......例如:
class Timeslip < ActiveRecord::Base
def self.by_car_trans(car, trans)
joins(:car)
.where("cars.trans IN (?) and cars.year IN (?) and cars.model ILIKE ?", trans, 1993..2002, car)
.order('et1320')
end
end
假设我没有传入我的参数,而是传入一个条件数组,其中键是字段名,值是字段值。例如,我会做这样的事情:
我会传入 [["field", "value", "operator"],["field", "value", "operator"]]
def self.using_conditions(conditions)
joins(:car)
conditions.each do |key, value|
where("cars.#{key} #{operator} ?", value)
end
end
但是,这不起作用,而且不是很灵活......我希望能够检测该值是否是一个数组,并使用 IN () 而不是 =,也许能够使用 ILIKE 来区分大小写条件也...
任何建议表示赞赏。我的主要目标是建立一个“列表”模型,用户可以在其中动态构建他们的条件,然后保存该列表以供将来使用。该列表将根据关联的汽车表过滤时间片模型......也许有更简单的方法来解决这个问题?