ruby-on-rails – 用于查找和排序帖子的Rails db查询
发布时间:2020-12-17 03:06:20 所属栏目:百科 来源:网络整理
导读:我的应用程序具有用户可以喜欢的设计(投票,使用acts_as_voteable).要在视图中查找设计,请使用 @design.votes.count 我正在制作一个热门页面,根据他们的票数展示最流行的设计.我只想要对他们至少有5票的设计.现在,我在视图中有这个,但我想将其推入控制器.到目
我的应用程序具有用户可以喜欢的设计(投票,使用acts_as_voteable).要在视图中查找设计,请使用
@design.votes.count 我正在制作一个热门页面,根据他们的票数展示最流行的设计.我只想要对他们至少有5票的设计.现在,我在视图中有这个,但我想将其推入控制器.到目前为止,我的控制器看起来像是显示所有设计并按照大多数投票顺序对它们进行排序. def popular @designs = Design.all @designs.sort! {|t1,t2| t2.votes.count <=> t1.votes.count} end 现在我只想确保设计的最低投票数为5. 以前,我这样做是错误的,并把它放在我的设计循环中 <% if design.vote.count > 5 %> ... <% end %> 谢谢! 解决方法
首先,您需要的行为在设计模型中更好地定义,而不是在控制器中定义,因为它处理数据.因此,在您的设计模型中,添加以下代码:
scope :most_popular,-> do results = select {|design| design.votes.count > 4 } results.sort! {|t1,t2| t2.votes.count <=> t1.votes.count} end 在您的设计模型中添加上面的两个范围方法,您可以在控制器代码中执行此操作: def popular @designs = Design.most_popular end 您的控制器代码最终变得更加清晰,并且您可以在任何其他需要的地方重复使用范围方法. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |