我需要通過ActiveRecord從表中獲取隨機記錄。我遵循了2006年Jamis Buck的例子。但是,我也通過Google搜索遇到了另一種方式(由于新用戶的限制,無法通過鏈接添加屬性): rand_id = rand(Model.count) rand_record = Model.first(:conditions => ["id >= ?", rand_id])我很好奇這里的其他人是如何做到的,或者是否有人知道哪種方法會更有效。
3 回答

慕森王
TA貢獻1777條經驗 獲得超3個贊
沒有至少兩個查詢,我還沒有找到一種理想的方法。
以下使用隨機生成的數字(直到當前記錄數)作為偏移量。
offset = rand(Model.count)
# Rails 4
rand_record = Model.offset(offset).first
# Rails 3
rand_record = Model.first(:offset => offset)
老實說,我一直在使用ORDER BY RAND()或RANDOM()(取決于數據庫)。如果您沒有性能問題,那么這不是性能問題。
- 3 回答
- 0 關注
- 635 瀏覽
添加回答
舉報
0/150
提交
取消