按Activerecord中的特定值排序

 sannyi 发布于 2023-02-13 12:44

在Ruby on Rails中,我试图通过当前用户是否获胜来订购玩家的匹配.

排序顺序为:

按当前用户是否为赢家排序

然后按created_at等排序

我无法弄清楚如何做到相当于:

Match.all.order('winner_id == ?', @current_user.id)

我知道这一行在语法上是不正确的,但希望它表达的顺序必须是:

1)当前用户获胜的比赛2)其他比赛

1 个回答
  • 您可以在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)
    

    隐藏肮脏.

    2023-02-13 12:46 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有