0

私のモデル:

class Contact < ActiveRecord::Base
  has_many :addresses
  has_many :emails
  has_many :websites
  accepts_nested_attributes_for :addresses, :emails, :websites
  attr_accessible :prefix, :first_name, :middle_name, :last_name, :suffix,
                  :nickname, :organization, :job_title, :department, :birthday,
                  :emails_attributes
end

class Email < ActiveRecord::Base
  belongs_to :contact
  validates_presence_of :account
  validates_format_of :account, :with => /\A([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})\Z/i, :on => :create
  attr_accessible :contact_id, :account, :label
end

次のクエリを実行すると、emails期待どおりに返されます。

c = Contact.find(3)
  Contact Load (3.2ms)  SELECT `contacts`.* FROM `contacts` LIMIT 1
=> #<Contact id: 3, prefix: nil, first_name: "Micah", middle_name: nil, last_name: "Alcorn", suffix: nil, nickname: nil, organization: nil, job_title: nil, department: nil, birthday: nil, created_at: "2011-07-04 23:50:04", updated_at: "2011-07-04 23:50:04">

c.emails
  Email Load (4.4ms)  SELECT `emails`.* FROM `emails` WHERE `emails`.`contact_id` = 3
=> [#<Email id: 3, contact_id: 3, account: "not@real.address", label: "work", created_at: "2011-07-04 23:50:04", updated_at: "2011-07-04 23:50:04">]

ただし、関係を試みて:includeも次のことはできません。

c = Contact.find(3, :include => :emails)
  Contact Load (0.5ms)  SELECT `contacts`.* FROM `contacts` WHERE `contacts`.`id` = 3 LIMIT 1
  Email Load (0.8ms)  SELECT `emails`.* FROM `emails` WHERE `emails`.`contact_id` IN (3)
=> #<Contact id: 3, prefix: nil, first_name: "Micah", middle_name: nil, last_name: "Alcorn", suffix: nil, nickname: nil, organization: nil, job_title: nil, department: nil, birthday: nil, created_at: "2011-07-04 23:50:04", updated_at: "2011-07-04 23:50:04">

ご覧のとおり、SQL は実行されていますが、電子メールは返されていません。メールを含むすべての連絡先を返すつもりなので、:joins何の役にも立ちません。私は何が欠けていますか?

4

1 に答える 1

2

メールはそこにあります。試しましたc.emailsか?Rails が追加の DB クエリを実行しなくても、電子メールがそこにあることがわかります。

これ:includeは、基本的に、Rails がオブジェクトにリレーションを事前設定するベスト エフォート方式を試行することを意味します。そのため、実際にリレーションを要求するときに追加の DB クエリは必要ありません。

http://api.rubyonrails.org/classes/ActiveRecord/Associations/ClassMethods.htmlのセクション「アソシエーションの一括読み込み」を参照してください。

この RailsCast もチェックしてみてください:
http://railscasts.com/episodes/181-include-vs-joins

于 2011-07-05T00:34:32.230 に答える