Cuando la base de datos crece, aparecen nuevos problemas, uno de ellos es que las tablas de la base de datos pueden no caber en memoria. En hostings baratos este problema se acentúa ya que no se suele contar con demasiada RAM. Con ruby on rails es muy fácil solventar esta dificultad.
Tomando como ejemplo una tabla muy grande de usuarios en la que hay que recalcular un campo para cada usuario.
User.find_each{|u| u.karma = calculate_karma(:user => u)}find_each toma bloques de 1000 usuarios y va devolviendo de uno en uno de forma transparente, se utilizan 1000 entradas por defecto pero se puede cambiar mediante el parámetro batch_size.
User.find_each(:batch_size => 200){|u| u.karma = calculate_karma(:user => u)}find_each se implementa usando find_in_batches, se puede llegar a mayor nivel de control usando esta función que devuelve directamente los grupos de entradas.
User.find_in_batches(:batch_size => 2000){|group| group.each{|u| u.karma = calculate_karma(:user => u)}}Puede que este último ejemplo parezca más complejo sin ningún tipo de beneficio, pero sería muy útil en caso de querer paralelizar el proceso.
User.find_in_batches(:batch_size => 2000){|group| Process.fork{calculate_karma(:group => group)}}