29 lines
		
	
	
		
			844 B
		
	
	
	
		
			Ruby
		
	
	
	
		
		
			
		
	
	
			29 lines
		
	
	
		
			844 B
		
	
	
	
		
			Ruby
		
	
	
	
| 
								 | 
							
								module  OrbitBasis
							 | 
						||
| 
								 | 
							
								  module BaseModel
							 | 
						||
| 
								 | 
							
								    extend ActiveSupport::Concern
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    # included do
							 | 
						||
| 
								 | 
							
								    #   scope :recent, desc(:_id)
							 | 
						||
| 
								 | 
							
								    #   scope :exclude_ids, Proc.new { |ids| where(:_id.nin => ids.map(&:to_i)) }
							 | 
						||
| 
								 | 
							
								    #   scope :by_week, where(:created_at.gte => 7.days.ago.utc)
							 | 
						||
| 
								 | 
							
								    # end
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    module ClassMethods
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      def find_in_batches(opts = {})
							 | 
						||
| 
								 | 
							
								        batch_size = opts[:batch_size] || 1000
							 | 
						||
| 
								 | 
							
								        start = opts.delete(:start).to_i || 0
							 | 
						||
| 
								 | 
							
								        objects = self.limit(batch_size).skip(start)
							 | 
						||
| 
								 | 
							
								        t = Time.new
							 | 
						||
| 
								 | 
							
								        while objects.any?
							 | 
						||
| 
								 | 
							
								          yield objects
							 | 
						||
| 
								 | 
							
								          start += batch_size
							 | 
						||
| 
								 | 
							
								          # Rails.logger.debug("processed #{start} records in #{Time.new - t} seconds") if Rails.logger.debug?
							 | 
						||
| 
								 | 
							
								          break if objects.size < batch_size
							 | 
						||
| 
								 | 
							
								          objects = self.limit(batch_size).skip(start)
							 | 
						||
| 
								 | 
							
								        end
							 | 
						||
| 
								 | 
							
								      end
							 | 
						||
| 
								 | 
							
								    end
							 | 
						||
| 
								 | 
							
								  end
							 | 
						||
| 
								 | 
							
								end
							 |