Railsのhas_manyで設定したorderを上書きする

has_manyするとき、新しい順に取り出すようにorder指定することはよくありますよね。

class User
  has_many :articles, :order => ‘updated_at DESC’
end

これで、@user.articles.firstなどとやれば最新記事が取得できます。

ところで、何かの都合で別の基準(たとえば古い順やタイトル順)で並び替えたい場合はどうしたらいいでしょうか?

@user.articles.order(‘updated_at ASC’)
#=> ORDER BY `updated_at` DESC, `updated_at` ASC

@user.articles.order(‘name ASC’)
#=> ORDER BY `updated_at` DESC, `name` ASC

これではダメですね。

困ったときのStackOverflow!!

そのまんまの答えがありました

@user.articles.reorder('updated_at ASC')

めでたしめでたし。

追記: reorder()はdeprecatedなのでexcept(:order).order()の方が良いらしいです

デザインも頼めるシステム開発会社をお探しならBPS株式会社までどうぞ 開発エンジニア積極採用中です! Ruby on Rails の開発なら実績豊富なBPS

この記事の著者

baba

ゆとりプログラマー。 高校時代から趣味でプログラミングを初め、そのままコードを書き続けて現在に至る。慶應義塾大学環境情報学部(SFC)卒業。BPS設立初期に在学中から参加している最古参メンバーの一人。Ruby on Rails、PHP、Androidアプリ、Windows/Macアプリ、超縦書の開発などを気まぐれにやる。軽度の資格マニアで、情報処理技術者試験(16区分17回 + 情報処理安全確保支援士試験)、技術士(情報工学部門)、Ruby Programmer Gold、AWSソリューションアーキテクト(アソシエイト)、日商簿記2級、漢検準1級などを保有。

babaの書いた記事

BPSアドベントカレンダー

週刊Railsウォッチ

インフラ

ActiveSupport探訪シリーズ