Sha256: bd7e07483ff9d091d1c1cce0f37f0848c5c24aec4ddb444308a6d7edc74cb6d6

Contents?: true

Size: 1.96 KB

Versions: 1

Compression:

Stored size: 1.96 KB

Contents

# frozen_string_literal: true
require "pry"
require "json"
require 'terminal-table'

class BulkseedMysql
  class Seed
    def inspect
      pretty_table = Terminal::Table.new do |t|
        t << @columns
        t.add_separator

        @values.each do |v|
          t << v
        end
      end

      <<~TXT
        ======= #{@table} =========
        #{ pretty_table }
      TXT
    end

    def initialize(table)
      @table = table
      @values = []
    end

    def data= data
      data.each do |item|
        case item
        when Array
          @values << item
        when Hash
          @columns ||= item.keys

          if @columns != item.keys
            raise <<~TXT
              Keys are not same to before
              table: #{@table}
              row: #{JSON.pretty_generate(item)}
            TXT
          end

          @values << item.values
        end
      end
    end

    def columns= columns
      @columns = columns
    end

    def table= table
      @table = table
    end

    def to_cmd
      values = @values.map do |rows|
        vals = rows.map do |v|
          # escape quotes
          s = %Q(#{v}).gsub('"', '\"')
          v.nil? ? "NULL" : "\"#{s}\""
        end

        "(#{ vals * "," })"
      end

      <<~SQL
        REPLACE INTO #{@table}
        (#{ @columns.map{ |a| %(`#{a}`) } * ',' })
        VALUES #{ values * "," }
      SQL
    end
  end

  def self.call(name = nil, conn = nil, &block)
    seed = new conn
    seed.prepare name, &block
    seed.call
  end

  attr_reader :seeds
  attr_accessor :conn

  def initialize(conn = nil)
    @conn = conn
    @conn ||= Mysql2::Client.new(
      host: ENV["DB_HOST"],
      username: ENV["DB_USER"],
      password: ENV["DB_PASSWORD"],
      database: ENV["DB_NAME"],
    )

    @seeds = []
  end

  def prepare(name = nil, &block)
    seed = Seed.new name
    yield seed

    @seeds << seed
  end

  def call
    @seeds.each do |s|
      puts s.inspect
      @conn.query s.to_cmd
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
bulkseed_mysql-0.1.0 lib/bulkseed_mysql.rb