0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

find_each

Posted at

今まであまりよく考えずにfindやeachメソッドを使ってきましたが、find_eachの存在を知り、調べてみました。

結論としては、大量のデータを取得するときにfindやeachだとメモリを圧迫するので、メモリを節約しながら大量のデータを取得する場合にはfind_eachを使った方が良いようです。

find_eachメソッドは、大量のレコードに対してループ処理を実行したい場合にメモリ不足を防ぐことが出来るメソッド

find_each

大量のレコードを扱う場合に使用することができます。例えば、1万件以上のレコードがある場合に、allやeachを使うとメモリを圧迫してしまうことがありますが、find_eachを使うと一定数ずつレコードを取得しながら処理を行うことができます。

以下は、usersテーブルからidが1以上のユーザーを全て取得し、それぞれのnameを出力する例です。

User.where("id >= 1").find_each do |user|
  puts user.name
end

この例では、idが1以上のユーザーが膨大にいる場合でも、find_eachを使うことで、一度に取得するレコード数を制限しているため、メモリを圧迫することなく処理を行うことができます。

じゃあ基本的にはfindeachを使うべき?

find_eachは膨大なレコードを処理する場合にメモリの使用量を抑えられるため、非常に有用です。

しかし、1つのレコードだけを取得する場合や、少数のレコードしか取得しない場合は、findの方がより簡潔かつ直感的です。つまり、データベースから取得するレコードの数によって、使い分けるべきです。

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?