首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用redis中排序的唯一I来显示用户?

如何使用redis中排序的唯一I来显示用户?
EN

Stack Overflow用户
提问于 2015-10-04 09:17:29
回答 2查看 69关注 0票数 1

我正试图为我的用户创建一个高分板。我正在使用redis-objects宝石来完成这项任务。

代码语言:javascript
复制
class User < ActiveRecord::Base
  include Redis::Objects
  sorted_set :leaderboard, global: true
  after_update :update_leaderboard

    def update_leaderboard
      self.class.leaderboard[id] = score
    end
end

使用这种方法,每次更新分数时,我都会得到用户I并按他们的分数排序。

代码语言:javascript
复制
User.leaderboard.revrange(0,2) #["3", "1", "2"]

我的问题是:

如何利用排序I的数组,并根据订单显示用户?假设我想在索引页面中对我的用户进行排序。

代码语言:javascript
复制
class UserController < ApplicationController
  def index
  @users = User.all
  end
end

谢谢。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-10-04 10:41:01

你可以这样做:

代码语言:javascript
复制
class UserController < ApplicationController
  def index
    ids = User.leaderboard.revrange(0,2)
    @users = User.all.sort_by { |u| ids.index(u.id) }
  end
end

有关更多信息,sorting-an-array-of-objects-given-an-ordered-list-of-ids

票数 0
EN

Stack Overflow用户

发布于 2015-10-04 09:51:46

find方法将接受一个数组,但是排序是一个问题.如果你不介意在应用程序级别排序..。

代码语言:javascript
复制
class UserController < ApplicationController
  def index
    arr = User.leaderboard.revrange(0,2)
    @users = User.find(arr).sort_by{|user| arr.index user.id}
  end
end

也许有人有更好的解决方案..。

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

https://stackoverflow.com/questions/32931899

复制
相关文章

相似问题

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