繁体   English   中英

如何在Redis中使用排序的唯一ID来显示用户?

[英]How do I use the sorted unique ids in redis to display users?

我正在尝试为我的用户创建一个高分板。 我正在为此任务使用redis-objects gem。

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

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

User.leaderboard.revrange(0,2) #["3", "1", "2"]

我的问题:

如何使用已排序ID的数组,并根据顺序显示用户? 可以说我想在索引页面中对我的用户进行排序。

class UserController < ApplicationController
  def index
  @users = User.all
  end
end

谢谢。

find方法将采用数组,但是排序是一个问题...如果您不介意在应用程序级别进行排序...

class UserController < ApplicationController
  def index
    arr = User.leaderboard.revrange(0,2)
    @users = User.find(arr).sort_by{|user| arr.index user.id}
  end
end

有人可能有更好的解决方案...

您可以这样做:

class UserController < ApplicationController
  def index
    ids = User.leaderboard.revrange(0,2)
    @users = User.all.sort_by { |u| ids.index(u.id) }
  end
end

有关更多信息,请对给定的ID排序的对象数组进行排序

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM