当前位置:  开发笔记 > 后端 > 正文

Ruby on Rails根据数据库值计算"排名"?

如何解决《RubyonRails根据数据库值计算"排名"?》经验,为你挑选了1个好方法。

有没有一种简单快捷的方法来使用Ruby on Rails计算数据库中字段的等级?例如,如果我有一个math_scores表,并且想要找到给定的MathScore.find(:all,:condtions => ...:order => ...),那么遍历所有这些表以查找测试成绩下降,但必须有一个更直接的方式...任何建议?

这是关于模式的一些信息,它只是一个简单的表:

first_name varchar(50)

last_name varchar(50)

test_id int

得分漂浮

澄清:我猜问题更接近于如何在执行时检索等级值:rank = MathScore.find_by_sql("select count(*)as rank from(select*from math_scores where score>(从high_scores中选择得分,其中test_id = 33 AND first_name ='John'AND last_name ='Doe')按分数desc)排序为s")

[#"3"}>]:Array基于查询,但我如何得到排名值?

提前谢谢,本



1> MatthewFord..:

您可以在Rails 2.2中使用命名范围来帮助解决此问题,例如.

class MathScore
  named_scope :passed, :conditions => {:score => 60..100 }
  named_scope :failed, :conditions => {:score => 0..59}
end

这将允许您在控制器中执行以下操作:

@passing_scores = MathScore.passed
@failing_scores = MathScore.failed

因此,您可以在视图中迭代它们.


回应您的澄清(在erb中):

<% your_array.each do |hs| %>
  <%= hs.rank %>
<% end %>

推荐阅读
吻过彩虹的脸_378
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有