加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – Rails 3 – 如何从带有订单的模型中获取行号

发布时间:2020-12-16 22:07:41 所属栏目:百科 来源:网络整理
导读:我正在整理一个具有排行榜概念的小应用程序.基本上,模型只是一个player_name和一个current_score. 我想要做的是获得特定玩家的排名,并且考虑到新的分数一直在进行,它需要是动态的.显然,我可以使用order by子句进行正常查找,然后我必须循环遍历每条记录.当我
我正在整理一个具有排行榜概念的小应用程序.基本上,模型只是一个player_name和一个current_score.

我想要做的是获得特定玩家的排名,并且考虑到新的分数一直在进行,它需要是动态的.显然,我可以使用order by子句进行正常查找,然后我必须循环遍历每条记录.当我有100,000行时,效率不高.

我应该采取什么方法的任何建议?

以下是表的迁移:

class CreateScores < ActiveRecord::Migration
  def self.up
    create_table :scores do |t|
      t.string  :player_name
      t.integer :current_score

      t.timestamps
    end
  end

  def self.down
    drop_table :scores
  end
end

编辑
举个例子,我有以下几点:

Score.select('player_name,current_score').limit(20)
=> [#<Score player_name: "Keith Hughes",current_score: 9>,#<Score player_name: "Diane Chapman",current_score: 8>,#<Score player_name: "Helen Dixon",current_score: 4>,#<Score player_name: "Donald Lynch",#<Score player_name: "Shawn Snyder",current_score: 2>,#<Score player_name: "Nancy Palmer",#<Score player_name: "Janet Arnold",current_score: 1>,#<Score player_name: "Sharon Torres",#<Score player_name: "Keith Ortiz",current_score: 5>,#<Score player_name: "Judith Day",current_score: 3>,#<Score player_name: "Gregory Watson",current_score: 7>,#<Score player_name: "Jeremy Welch",#<Score player_name: "Sharon Oliver",#<Score player_name: "Donald Lewis",#<Score player_name: "Timothy Frazier",#<Score player_name: "John Richards",#<Score player_name: "Carolyn White",#<Score player_name: "Ronald Smith",#<Score player_name: "Emily Freeman",#<Score player_name: "Gregory Wright",current_score: 2>]

我如何计算出“唐纳德刘易斯”的排名?

解决方法

您可以计算具有更高current_score的记录数.您仍然必须按记录执行此操作(或在您的sql中执行子查询).
class Score < ActiveRecord::Base

  def ranking
    Score.count(:conditions => ['current_score > ?',self.current_score])
  end

end

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读