Sha256: 304102013e27046d82d4771c2211606e97c5b1c7afa610d984bf3d5ab8ade023

Contents?: true

Size: 1.79 KB

Versions: 9

Compression:

Stored size: 1.79 KB

Contents

# frozen_string_literal: true

require 'bundler/inline'

gemfile do
  source 'https://rubygems.org'
  gem 'pg', github: 'ged/ruby-pg'
  gem 'mini_sql', path: '../'
  gem 'activerecord'
  gem 'activemodel'
  gem 'benchmark-ips'
  gem 'draper'
  gem 'pry'
end

require 'active_record'
require 'benchmark/ips'
require 'mini_sql'

require '../mini_sql/bench/shared/generate_data'

ar_connection, conn_config = GenerateData.new(count_records: 1_000).call
MINI_SQL = MiniSql::Connection.get(ar_connection.raw_connection)


Benchmark.ips do |r|
  r.report('query_hash') do |n|
    while n > 0
      MINI_SQL.query_hash('select id, title from topics order by id limit 1000').each do |hash|
        [hash['id'], hash['title']]
      end
      n -= 1
    end
  end
  r.report('query_array') do |n|
    while n > 0
      MINI_SQL.query_array('select id, title from topics order by id limit 1000').each do |id, title|
        [id, title]
      end
      n -= 1
    end
  end
  r.report('query') do |n|
    while n > 0
      MINI_SQL.query('select id, title from topics order by id limit 1000').each do |obj|
        [obj.id, obj.title]
      end
      n -= 1
    end
  end

  r.compare!
end

# Comparison:
#          query_array:     1663.3 i/s
#                query:     1254.5 i/s - 1.33x  (± 0.00) slower
#           query_hash:     1095.4 i/s - 1.52x  (± 0.00) slower


Benchmark.ips do |r|
  r.report('query_single') do |n|
    while n > 0
      MINI_SQL.query_single('select id from topics order by id limit 1000')
      n -= 1
    end
  end
  r.report('query_array') do |n|
    while n > 0
      MINI_SQL.query_array('select id from topics order by id limit 1000').flatten
      n -= 1
    end
  end

  r.compare!
end

# Comparison:
#         query_single:     2445.1 i/s
#          query_array:     1681.1 i/s - 1.45x  (± 0.00) slower

Version data entries

9 entries across 9 versions & 1 rubygems

Version Path
mini_sql-1.6.0 bench/mini_sql_methods_perf.rb
mini_sql-1.5.0 bench/mini_sql_methods_perf.rb
mini_sql-1.4.0 bench/mini_sql_methods_perf.rb
mini_sql-1.3.0 bench/mini_sql_methods_perf.rb
mini_sql-1.2.0 bench/mini_sql_methods_perf.rb
mini_sql-1.1.3 bench/mini_sql_methods_perf.rb
mini_sql-1.1.2 bench/mini_sql_methods_perf.rb
mini_sql-1.1.1 bench/mini_sql_methods_perf.rb
mini_sql-1.1.0 bench/mini_sql_methods_perf.rb