Sha256: a992224cd4e8c630bcf15e9deae9e512992a59b95abe9e772dcb983876461d68
Contents?: true
Size: 1.81 KB
Versions: 25
Compression:
Stored size: 1.81 KB
Contents
module ActiveRecord ### # This class encapsulates a Result returned from calling +exec_query+ on any # database connection adapter. For example: # # x = ActiveRecord::Base.connection.exec_query('SELECT * FROM foo') # x # => #<ActiveRecord::Result:0xdeadbeef> class Result include Enumerable attr_reader :columns, :rows, :column_types def initialize(columns, rows, column_types = {}) @columns = columns @rows = rows @hash_rows = nil @column_types = column_types end def each hash_rows.each { |row| yield row } end def to_hash hash_rows end alias :map! :map alias :collect! :map # Returns true if there are no records. def empty? rows.empty? end def to_ary hash_rows end def [](idx) hash_rows[idx] end def last hash_rows.last end def initialize_copy(other) @columns = columns.dup @rows = rows.dup @hash_rows = nil end private def hash_rows @hash_rows ||= begin # We freeze the strings to prevent them getting duped when # used as keys in ActiveRecord::Base's @attributes hash columns = @columns.map { |c| c.dup.freeze } @rows.map { |row| # In the past we used Hash[columns.zip(row)] # though elegant, the verbose way is much more efficient # both time and memory wise cause it avoids a big array allocation # this method is called a lot and needs to be micro optimised hash = {} index = 0 length = columns.length while index < length hash[columns[index]] = row[index] index += 1 end hash } end end end end
Version data entries
25 entries across 25 versions & 1 rubygems