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 に答える