簡體   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