加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – 按Activerecord中的特定值排序

发布时间:2020-12-17 02:39:48 所属栏目:百科 来源:网络整理
导读:在 Ruby on Rails中,我试图通过当前用户是否获胜来订购玩家的匹配. 排序顺序为: 按当前用户是否为赢家排序 然后按created_at等排序 我无法弄清楚如何做到相当于: Match.all.order('winner_id == ?',@current_user.id) 我知道这一行在语法上是不正确的,但希
在 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)

隐藏肮脏.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读