Rails 3: вызов базы данных по ассоциации has_many

Привет, у меня много ассоциаций, где у «сообщений» много «ощущений», я хотел бы выяснить, как найти все сообщения с определенным чувством пользователя. Модель «Мои чувства» имеет атрибут «имя».

class User < ActiveRecord::Base
  has_many :posts, :dependent => :destroy
  devise :database_authenticatable, :registerable,
         :recoverable, :rememberable, :trackable, :validatable
end

class Post < ActiveRecord::Base
  has_many :feelingships
  has_many :feelings, :through => :feelingships
  belongs_to :user
end

class Feeling < ActiveRecord::Base
  has_many :feelingships
  has_many :posts, :through => :feelingships
end


class Feelingship < ActiveRecord::Base
  belongs_to :post
  belongs_to :feeling
  attr_accessible :post_id, :feeling_id
end

Я пробовал это, но там написано, что у меня неправильная ассоциация: «ActiveRecord :: ConfigurationError: ассоциация с именем 'feel' не найдена; возможно, вы ее написали с ошибкой?»

 def feeling
  @user = User.find(params[:id])
  @feed_items= @user.posts.includes(:feeling).where(
          ['`feelings`.name = ?', params[:feeling]])
  @feed_items = @feed_items.paginate(:per_page => "10", :page => params[:page])
render 'shared/_feed', :layout => 'head_layout'
end

person trying_hal9000    schedule 23.10.2011    source источник
comment
Какую ленту вызывает @user? Скорее всего, это должны быть сообщения   -  person Arnaud    schedule 24.10.2011


Ответы (1)


Аргумент includes должен быть :feelings - обратите внимание на множественное число, которым названа ваша ассоциация.

Так и должно быть:

@user.posts.includes(:feelings)
person Cody Caughlan    schedule 24.10.2011