在Ruby on Rails中,我试图通过当前用户是否获胜来订购玩家的匹配.
排序顺序为:
按当前用户是否为赢家排序
然后按created_at等排序
我无法弄清楚如何做到相当于:
Match.all.order('winner_id == ?', @current_user.id)
我知道这一行在语法上是不正确的,但希望它表达的顺序必须是:
1)当前用户获胜的比赛2)其他比赛
您可以在SQL ORDER BY子句中使用CASE表达式.但是,AR不相信在ORDER BY中使用占位符,所以你必须做这样讨厌的事情:
by_owner = Match.send(:sanitize_sql_array, [ 'case when winner_id = %d then 0 else 1 end', @current_user.id ]) Match.order(by_owner).order(:created_at)
这应该在任何SQL数据库中都是一样的(假设你@current_user.id
当然是一个整数).
通过使用类方法作为范围,可以减少不愉快:
class Match < ActiveRecord::Base def self.this_person_first(id) by_owner = sanitize_sql_array([ 'case when winner_id = %d then 0 else 1 end', id]) order(by_owner) end end # and later... Match.this_person_first(@current_user.id).order(:created_at)
隐藏肮脏.