首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >在控制员级别有效地查询所有帖子的评论?

在控制员级别有效地查询所有帖子的评论?
EN

Stack Overflow用户
提问于 2013-06-20 09:32:04
回答 2查看 102关注 0票数 0

我在posts控制器中有一个索引操作,视图显示所有帖子,每个帖子后面都有评论。我当前的实现是,在嵌入的html文件中,在@posts.each do |p|块中,我使用p.comments来获取每个帖子的所有评论。然而,仅仅在视图中这样做似乎并不好,但我找不到在控制器中这样做的方法。有没有人能给点建议?或者这就是正确的做法吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-06-20 09:36:49

在您的控制器中,当您查询帖子时,使用includes(:comments)将SQL查询的数量从1+n减少到2:

代码语言:javascript
代码运行次数:0
运行
复制
@posts = Post.includes(:comments).where(......)

您可以将代码保留在视图中,因为p.comments不会触发更多的SQL查询。

查看教程Eager loading associations

票数 4
EN

Stack Overflow用户

发布于 2013-06-20 09:46:13

Arie在解决n+1问题上做得很好。在视图方面,您仍然可以使用相同的方法,但最好使用集合部分:

代码语言:javascript
代码运行次数:0
运行
复制
# posts/index.html.erb
<%= render @posts %>

这将查找位于/views/posts/_post.html.erb的部分,因为向它发送一个post变量。它将对@posts数组中的每个Post模型执行此操作。

对于注释,在_post.html.erb中你可以这样写:

代码语言:javascript
代码运行次数:0
运行
复制
# /views/posts/_post.html.erb
<% # Post content here %>
<%= render post.comments %>

与posts集合一样,它将使用位于/views/comments/_comment.html.erb的部分内容呈现每个评论

有关更多详细信息,请查看rails guide

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17203958

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档