Sha256: 4f23102d329461382c38a973c143cbb724f2eac2f1b6fd90d5425a1bedf7dbe4
Contents?: true
Size: 1.55 KB
Versions: 2
Compression:
Stored size: 1.55 KB
Contents
# Copyright (c) 2011, SoundCloud Ltd., Rany Keddo, Tobias Bielohlawek, Tobias # Schmidt require 'active_record' require 'lhm/table' require 'lhm/invoker' require 'lhm/version' # Large hadron migrator - online schema change tool # # @example # # Lhm.change_table(:users) do |m| # m.add_column(:arbitrary, "INT(12)") # m.add_index([:arbitrary, :created_at]) # m.ddl("alter table %s add column flag tinyint(1)" % m.name) # end # module Lhm # Alters a table with the changes described in the block # # @param [String, Symbol] table_name Name of the table # @param [Hash] options Optional options to alter the chunk / switch behavior # @option options [Fixnum] :stride # Size of a chunk (defaults to: 40,000) # @option options [Fixnum] :throttle # Time to wait between chunks in milliseconds (defaults to: 100) # @option options [Boolean] :atomic_switch # Use atomic switch to rename tables (defaults to: true) # If using a version of mysql affected by atomic switch bug, LHM forces user # to set this option (see SqlHelper#supports_atomic_switch?) # @yield [Migrator] Yielded Migrator object records the changes # @return [Boolean] Returns true if the migration finishes # @raise [Error] Raises Lhm::Error in case of a error and aborts the migration def self.change_table(table_name, options = {}, &block) connection = ActiveRecord::Base.connection origin = Table.parse(table_name, connection) invoker = Invoker.new(origin, connection) block.call(invoker.migrator) invoker.run(options) true end end
Version data entries
2 entries across 2 versions & 2 rubygems
Version | Path |
---|---|
sbader-lhm-1.1.0 | lib/lhm.rb |
lhm-1.1.0 | lib/lhm.rb |