如何在与连接关联的where子句中使用命名关联?
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
产生
"SELECT `owners`.* FROM `owners` INNER JOIN `pets` ON `pets`.`owner_id` = `owners`.`id` WHERE (`dogs`.`name` = 'fido')"
请注意,WHERE
子句在dogs
表而不是pets
表中查找
供参考:
http://guides.rubyonrails.org/active_record_querying.html#specifying-conditions-on-the-joined-tables
答案 0 :(得分:1)
看起来这是预期的行为 - 您需要在哈希中指定表名,而不是关联名。这有点不幸,因为我认为根据他们的模型定义构建查询更有用,而不是他们坐在前面的模式。