1

我的应用程序中有以下关联:

# user.rb
has_many :posts, :dependent => :destroy
has_many :likes, :dependent => :destroy

# post.rb
belongs_to :user
has_many :likes, :dependent => :destroy


# like.rb
belongs_to :user
belongs_to :post

当我尝试访问用户喜欢的所有帖子时,我正在使用以下循环

@user = User.find(params[:id])
@posts_user_likes = []
@user.likes.each do |like| # TODO optimize
  @posts_user_likes << Post.find_by_id(like.post_id)
end

但这似乎效率很低。

使用不同的关联或不同的循环方式来改进我的代码的最佳方法是什么?

4

1 回答 1

5

添加has_many :liked_posts, :through => :likes, :class_name => 'Post'User然后调用 User.find(params[:id]).liked_posts.

于 2012-01-30T23:12:19.560 回答