У меня возникли проблемы с подключением моих моделей, или я как-то не осведомлен о том, как запросить ассоциации.Прослушивание через ассоциации рельсов
class Entry < ActiveRecord::Base
has_one :category
end
class Category < ActiveRecord::Base
belongs_to :entry
end
Теперь, если я иду в мой рельсы консоли и попросить Entry.first
, я получаю:
Entry Load (0.1ms) SELECT "entries".* FROM "entries" LIMIT 1
=> #<Entry id: 1, category_id: 1, duration: 2.0, image: "3", note: "4", url: "5", created_at: "2012-03-03 02:22:23", updated_at: "2012-03-03 02:22:23">
и если я спрошу Category.first
для я получаю:
Category Load (0.1ms) SELECT "categories".* FROM "categories" LIMIT 1
=> #<Category id: 1, name: "Dev", created_at: "2012-03-03 02:17:17", updated_at: "2012-03-03 02:17:17">
Но если я запросить Entry.first.category.name
, он ломается, и я получаю:
Entry Load (0.1ms) SELECT "entries".* FROM "entries" LIMIT 1
NoMethodError: undefined method `category' for #<Entry:0x007fec4d217848>
from /Users/john/.rbenv/versions/1.9.2-p290/lib/ruby/gems/1.9.1/gems/activemodel-3.2.1/lib/active_model/attribute_methods.rb:407:in `method_missing'
from /Users/john/.rbenv/versions/1.9.2-p290/lib/ruby/gems/1.9.1/gems/activerecord-3.2.1/lib/active_record/attribute_methods.rb:126:in `method_missing'
from (irb):63
from /Users/john/.rbenv/versions/1.9.2-p290/lib/ruby/gems/1.9.1/gems/railties-3.2.1/lib/rails/commands/console.rb:47:in `start'
from /Users/john/.rbenv/versions/1.9.2-p290/lib/ruby/gems/1.9.1/gems/railties-3.2.1/lib/rails/commands/console.rb:8:in `start'
from /Users/john/.rbenv/versions/1.9.2-p290/lib/ruby/gems/1.9.1/gems/railties-3.2.1/lib/rails/commands.rb:41:in `<top (required)>'
from script/rails:6:in `require'
from script/rails:6:in `<main>'
Почему это? Как я могу получить имя для категории через запись? Что я делаю не так?
Спасибо. Я попробовал оба направления, но не знал, что мне нужно перезагрузить консоль рельсов после внесения изменений в модель. Теперь я знаю! :) – John