Comment utiliser une association nommée dans la clause where associée à une jointure?ActiveRecord :: Relation ne peut pas utiliser l'association nommée dans la clause where de la jointure
class Pet < ActiveRecord::Base
belongs_to :owner
end
class Owner < ActiveRecord::Base
has_many :dogs, :class_name => 'Pet', :foreign_key => :owner_id
end
Owner.joins(:dogs).where(:dogs => {:name => 'fido'}).to_sql
génère:
"SELECT `owners`.* FROM `owners` INNER JOIN `pets` ON `pets`.`owner_id` = `owners`.`id` WHERE (`dogs`.`name` = 'fido')"
Notez que la WHERE
clause est à la recherche dans le tableau dogs
au lieu de la table pets
Pour référence:
http://guides.rubyonrails.org/active_record_querying.html#specifying-conditions-on-the-joined-tables