我在posts控制器中有一个索引操作,视图显示所有帖子,每个帖子后面都有评论。我当前的实现是,在嵌入的html文件中,在@posts.each do |p|
块中,我使用p.comments
来获取每个帖子的所有评论。然而,仅仅在视图中这样做似乎并不好,但我找不到在控制器中这样做的方法。有没有人能给点建议?或者这就是正确的做法吗?
发布于 2013-06-20 01:36:49
在您的控制器中,当您查询帖子时,使用includes(:comments)
将SQL查询的数量从1+n减少到2:
@posts = Post.includes(:comments).where(......)
您可以将代码保留在视图中,因为p.comments
不会触发更多的SQL查询。
发布于 2013-06-20 01:46:13
Arie在解决n+1问题上做得很好。在视图方面,您仍然可以使用相同的方法,但最好使用集合部分:
# posts/index.html.erb
<%= render @posts %>
这将查找位于/views/posts/_post.html.erb
的部分,因为向它发送一个post
变量。它将对@posts
数组中的每个Post模型执行此操作。
对于注释,在_post.html.erb
中你可以这样写:
# /views/posts/_post.html.erb
<% # Post content here %>
<%= render post.comments %>
与posts集合一样,它将使用位于/views/comments/_comment.html.erb
的部分内容呈现每个评论
有关更多详细信息,请查看rails guide
https://stackoverflow.com/questions/17203958
复制相似问题