Sha256: b1c69209cf6641f4394a238fc8fadb51384993988fa8073ee477450fb0fe2dc2
Contents?: true
Size: 1.66 KB
Versions: 22
Compression:
Stored size: 1.66 KB
Contents
module Pacer::Routes # Additional iteration methods that allow for rapid data # manipulation in transactional graphs. Bulk operations automatically # manage transactions in larger batches rather than on every # element created or removed or every property set. module BulkOperations # Like bulk_job that also returns an array of results def bulk_map(size = nil, target_graph = nil) result = [] bulk_job(size, target_graph) do |e| result << yield(e) end result end # Iterates over each element in the route, controlling # transactions so that they are only committed once every # +size+ records. def bulk_job(size = nil, target_graph = nil, pre_commit = nil) target_graph ||= graph graph.read_transaction do if target_graph and not target_graph.in_bulk_job? begin target_graph.in_bulk_job = true size ||= target_graph.bulk_job_size counter = 0 print "Bulk job ->" if Pacer.verbose? each_slice(size) do |slice| target_graph.transaction(nesting: true) do print " #{counter}" if Pacer.verbose? counter += size slice.each do |element| yield element end pre_commit.call if pre_commit end end ensure puts '!' if Pacer.verbose? target_graph.in_bulk_job = false end elsif target_graph each do |element| yield element end else raise 'No graph in route for bulk job' end end end end end
Version data entries
22 entries across 22 versions & 1 rubygems