Class: ActiveRecord::Batches::BatchEnumerator
- Includes:
- Enumerable
- Defined in:
- activerecord/lib/active_record/relation/batches/batch_enumerator.rb
Instance Method Summary collapse
-
#each ⇒ Object
Yields an ActiveRecord::Relation object for each batch of records.
-
#each_record ⇒ Object
Looping through a collection of records from the database (using the
all
method, for example) is very inefficient since it will try to instantiate all the objects at once. -
#initialize(of: 1000, start: nil, finish: nil, relation:) ⇒ BatchEnumerator
constructor
:nodoc:.
Methods included from Enumerable
#as_json, #compact_blank, #exclude?, #excluding, #including, #index_by, #index_with, #many?, #pluck, #sum, #without
Constructor Details
#initialize(of: 1000, start: nil, finish: nil, relation:) ⇒ BatchEnumerator
:nodoc:
8 9 10 11 12 13 |
# File 'activerecord/lib/active_record/relation/batches/batch_enumerator.rb', line 8 def initialize(of: 1000, start: nil, finish: nil, relation:) #:nodoc: @of = of @relation = relation @start = start @finish = finish end |
Instance Method Details
#each ⇒ Object
Yields an ActiveRecord::Relation object for each batch of records.
Person.in_batches.each do |relation|
relation.update_all(awesome: true)
end
62 63 64 65 66 |
# File 'activerecord/lib/active_record/relation/batches/batch_enumerator.rb', line 62 def each enum = @relation.to_enum(:in_batches, of: @of, start: @start, finish: @finish, load: false) return enum.each { |relation| yield relation } if block_given? enum end |
#each_record ⇒ Object
Looping through a collection of records from the database (using the all
method, for example) is very inefficient since it will try to instantiate all the objects at once.
In that case, batch processing methods allow you to work with the records in batches, thereby greatly reducing memory consumption.
Person.in_batches.each_record do |person|
person.do_awesome_stuff
end
Person.where("age > 21").in_batches(of: 10).each_record do |person|
person.party_all_night!
end
If you do not provide a block to #each_record, it will return an Enumerator for chaining with other methods:
Person.in_batches.each_record.with_index do |person, index|
person.award_trophy(index + 1)
end
36 37 38 39 40 41 42 |
# File 'activerecord/lib/active_record/relation/batches/batch_enumerator.rb', line 36 def each_record return to_enum(:each_record) unless block_given? @relation.to_enum(:in_batches, of: @of, start: @start, finish: @finish, load: true).each do |relation| relation.records.each { |record| yield record } end end |