Итак, у меня появилась эта безумная идея, что я хотел применить область действия к включенной ассоциации.Это то, что я понял, и, кажется, работает нормально:
class Event < ActiveRecord::Base
has_many :races
has_many :bad_races, :conditions => Race.bad_medals_sql, :class_name => "Race"
end
class Race < ActiveRecord::Base
def self.bad_medals_sql
arel_table[:prizes].eq('medals').to_sql
# This returns a string
# "`races`.`prizes` = 'medals'"
end
def self.bad_medals
where(bad_medals_sql)
end
end
Event.includes(:bad_races)
Reloading...
Event Load (0.4ms) SELECT `events`.* FROM `events`
Race Load (0.5ms) SELECT `races`.* FROM `races` WHERE (`races`.event_id IN (1,2,3,4) AND (`races`.`prizes` = 'medals'))
Проблема в том, что это действительно тупо.Чтобы определить область действия в Race (чтобы использовать ее в другом месте) и использовать ее в ассоциации события, у меня должно быть два метода в Race.Для каждой области.
Я уверен, что мог бы обернуть шаблон в плагин или что-то подобное, но я бы предпочел использовать нативный AR / ARel, если это возможно.Есть идеи для этого?