1

如何在与联接关联的 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

4

1 回答 1

1

看来这是预期的行为 - 您需要在哈希中指定表名,而不是关联名称。这有点不幸,因为我认为更多地基于它们的模型定义而不是基于它们前面的模式来构造查询会很有用。

于 2010-11-12T23:50:58.363 回答