カテゴリ: Rails 更新日: 2026/01/22

RailsモデルとActive Record基礎|バッチ処理とfind_in_batchesで大規模データを安全に処理する方法

バッチ処理とfind_in_batches:大規模データを安全に処理
バッチ処理とfind_in_batches:大規模データを安全に処理

先生と生徒の会話形式で理解しよう

生徒

「Railsでたくさんのデータを一気に処理したら、アプリが止まってしまいました……」

先生

「それはバッチ処理のやり方が原因かもしれません。大量データは安全に分けて扱う必要があります。」

生徒

「find_in_batchesって聞いたことはありますが、何をしているのか分かりません。」

先生

「では、箱に分けて荷物を運ぶ例えで、順番に説明していきましょう。」

1. バッチ処理とは?Railsで大量データを扱う考え方

1. バッチ処理とは?Railsで大量データを扱う考え方
1. バッチ処理とは?Railsで大量データを扱う考え方

バッチ処理とは、たくさんのデータをまとめて処理する方法のことです。 Railsでは、ユーザー全員の情報を更新したり、 古いデータを一括で整理したりする場面で使われます。

ただし、データが多い状態で一気に処理すると、 メモリを大量に使ってしまい、 アプリが遅くなったり止まったりします。 初心者の方は、 「重い荷物を一度に運ぼうとして腰を痛める」 イメージをすると分かりやすいです。

2. なぜ大量データを一気に処理してはいけないのか

2. なぜ大量データを一気に処理してはいけないのか
2. なぜ大量データを一気に処理してはいけないのか

RailsでModel.all.eachのような書き方をすると、 すべてのデータを一度にメモリに読み込みます。 データが少ないうちは問題ありませんが、 件数が増えると大きな負担になります。


User.all.each do |user|
  user.update(active: true)
end

このコードは分かりやすいですが、 ユーザーが何万人もいる場合、 非常に危険です。 サーバーが悲鳴を上げる原因になります。

3. find_in_batchesとは?安全に分けて処理する仕組み

3. find_in_batchesとは?安全に分けて処理する仕組み
3. find_in_batchesとは?安全に分けて処理する仕組み

find_in_batchesは、 データを小さなまとまりに分けて、 順番に処理するためのRailsの仕組みです。

これは、「荷物を小さな箱に分けて、 何度も往復して運ぶ」方法に似ています。 体にもサーバーにも優しいやり方です。


User.find_in_batches(batch_size: 1000) do |users|
  users.each do |user|
    user.update(active: true)
  end
end

この例では、ユーザーを1000件ずつ読み込み、 少しずつ処理しています。 メモリを使いすぎず、 安定した動作が期待できます。

4. find_eachとの違いも知っておこう

4. find_eachとの違いも知っておこう
4. find_eachとの違いも知っておこう

Railsにはfind_eachという 似た仕組みもあります。 こちらは、内部でfind_in_batchesを使いながら、 1件ずつ処理してくれます。


User.find_each do |user|
  user.update(active: true)
end

初心者の方は、 「1件ずつ処理したいならfind_each」 「まとまり単位で処理したいならfind_in_batches」 と覚えておくと十分です。

5. バッチ処理で気をつけたいポイント

5. バッチ処理で気をつけたいポイント
5. バッチ処理で気をつけたいポイント

バッチ処理では、 途中でエラーが起きる可能性も考える必要があります。 そのため、 何件ずつ処理するかを意識し、 失敗しても被害が小さくなる設計が大切です。

関連記事:
カテゴリの一覧へ
新着記事
New1
Ruby
“すべてはオブジェクト”を体感!初心者向けRubyのオブジェクト指向入門【irbで学ぶ】
New2
Ruby
Rubyの標準入出力を完全ガイド!puts・print・pの違いとデバッグ活用法
New3
Ruby
Gemとは?RubyGemsとBundlerを初心者向けに完全解説!依存関係管理も図解でわかりやすく理解
New4
Ruby
Rubyの文字エンコーディング入門!UTF-8・マジックコメント・外部/内部エンコーディングを完全解説
人気記事
No.1
Java&Spring記事人気No1
Ruby
Rubyのreduceとinject入門!合計計算や集計を初心者向けに分かりやすく解説
No.2
Java&Spring記事人気No2
Ruby
Rubyの文字列エンコーディング完全ガイド!Encoding・force_encoding・encodeを初心者向け解説
No.3
Java&Spring記事人気No3
Ruby
Rubyの始め方ガイド:インストールから最初のHello Worldまで(Windows/Mac/Linux)
No.4
Java&Spring記事人気No4
データベース
PostgreSQLのWHERE句を徹底解説!初心者でもわかるSQLデータ抽出の基本
No.5
Java&Spring記事人気No5
Ruby
Rubyのfind/detect/find_indexを徹底解説!目的のデータを素早く探す方法
No.6
Java&Spring記事人気No6
Ruby
Rubyで比較演算子を完全解説!==・===・<=>・eql? の使い分け
No.7
Java&Spring記事人気No7
Ruby
Rubyのselect/reject/filterの使い方を完全解説!初心者向けの条件抽出レシピ
No.8
Java&Spring記事人気No8
データベース
PostgreSQLで順位付け!ROW_NUMBER関数の使い方を初心者向けに徹底解説