ActiveRecord :: Relation не может использовать именованную ассоциацию, в которой предложение объединения - PullRequest
1 голос
/ 05 ноября 2010

Как использовать именованную ассоциацию в предложении 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

1 Ответ

1 голос
/ 13 ноября 2010

Похоже, что это ожидаемое поведение - вам нужно указать имя таблицы в хэше, а не имя ассоциации.Это немного прискорбно, потому что я думаю, что было бы полезно создавать запросы, основанные больше на определении их модели, а не на схеме, перед которой они располагаются.

...