Rails ActiveRecordで前後のレコードを取得する

ActiveRecord モデルのインスタンスで前後のレコードを取得したかったのですけど、Rails 標準の API では見つかりませんでした。some_instance.previous, some_instance.next で、some_instance の前後レコードのインスタンスを取得できるようにしたかった。

— 環境 —
rails 4.1
activerecord 4.1

previous, next メソッドを対象モデルに実装

以下のように該当のモデルに、previous, next インスタンスメソッドを作成しました。

検索して調べてたら、id から ±1 して実装してある例も見つけたのですけど、それだとレコードが削除された時に id が抜けている可能性があるので汎用的でないと考えました。

なので、現在のインスタンス(self)の id より小さい/大きいかで判定。各々、直前(previou)/直後(next) のレコードを取得しています。

これで当初の目論見通り some_instance.previous, some_instance.next で、前後のレコードのインスタンスを簡単に取得できるようになり大変便利。

 

Leave Your Message!








  • トラックバックURL