Rails 3: вызов базы данных в ассоциации has_many - PullRequest
0 голосов
/ 24 октября 2011

Привет, у меня есть ассоциация "многие ко многим", где "посты" имеют много "чувств", я хотел бы выяснить, как найти все посты с определенным чувством пользователя. У моей модели Feeling есть атрибут name.

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: Ассоциация с именем« смысл »не найдена; возможно, вы ее неправильно написали?»

 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

1 Ответ

1 голос
/ 24 октября 2011

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

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

@user.posts.includes(:feelings)
...