Module: ArJdbc::MySQL::BulkChangeTable
- Included in:
- ArJdbc::MySQL
- Defined in:
- lib/arjdbc/mysql/bulk_change_table.rb
Instance Method Summary collapse
- #add_column_sql(table_name, column_name, type, options = {}) ⇒ Object
- #add_index_sql(table_name, column_name, options = {}) ⇒ Object protected
- #add_timestamps_sql(table_name, options = {}) ⇒ Object protected
- #bulk_change_table(table_name, operations) ⇒ Object
- #change_column_sql(table_name, column_name, type, options = {}) ⇒ Object
- #remove_column_sql(table_name, column_name, type = nil, options = {}) ⇒ Object protected
- #remove_columns_sql(table_name, *column_names) ⇒ Object protected
- #remove_index_sql(table_name, options = {}) ⇒ Object protected
- #remove_timestamps_sql(table_name) ⇒ Object protected
- #rename_column_sql(table_name, column_name, new_column_name) ⇒ Object
- #supports_bulk_alter? ⇒ Boolean
Instance Method Details
#add_column_sql(table_name, column_name, type, options = {}) ⇒ Object
32 33 34 35 36 37 |
# File 'lib/arjdbc/mysql/bulk_change_table.rb', line 32 def add_column_sql(table_name, column_name, type, = {}) add_column_sql = "ADD #{quote_column_name(column_name)} #{type_to_sql(type, [:limit], [:precision], [:scale])}" (add_column_sql, ) add_column_position!(add_column_sql, ) add_column_sql end |
#add_index_sql(table_name, column_name, options = {}) ⇒ Object (protected)
117 118 119 120 |
# File 'lib/arjdbc/mysql/bulk_change_table.rb', line 117 def add_index_sql(table_name, column_name, = {}) index_name, index_type, index_columns = (table_name, column_name, ) "ADD #{index_type} INDEX #{index_name} (#{index_columns})" end |
#add_timestamps_sql(table_name, options = {}) ⇒ Object (protected)
127 128 129 |
# File 'lib/arjdbc/mysql/bulk_change_table.rb', line 127 def (table_name, = {}) [add_column_sql(table_name, :created_at, :datetime, ), add_column_sql(table_name, :updated_at, :datetime, )] end |
#bulk_change_table(table_name, operations) ⇒ Object
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 |
# File 'lib/arjdbc/mysql/bulk_change_table.rb', line 14 def bulk_change_table(table_name, operations) sqls = operations.map do |command, args| table, arguments = args.shift, args method = :"#{command}_sql" if respond_to?(method, true) send(method, table, *arguments) else raise "Unknown method called : #{method}(#{arguments.inspect})" end end sqls.flatten! execute("ALTER TABLE #{quote_table_name(table_name)} #{sqls.join(", ")}") end |
#change_column_sql(table_name, column_name, type, options = {}) ⇒ Object
45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 |
# File 'lib/arjdbc/mysql/bulk_change_table.rb', line 45 def change_column_sql(table_name, column_name, type, = {}) column = column_for(table_name, column_name) unless () [:default] = column.default end unless .has_key?(:null) [:null] = column.null end change_column_sql = "CHANGE #{quote_column_name(column_name)} #{quote_column_name(column_name)} #{type_to_sql(type, [:limit], [:precision], [:scale])}" (change_column_sql, ) add_column_position!(change_column_sql, ) change_column_sql end |
#remove_column_sql(table_name, column_name, type = nil, options = {}) ⇒ Object (protected)
109 110 111 |
# File 'lib/arjdbc/mysql/bulk_change_table.rb', line 109 def remove_column_sql(table_name, column_name, type = nil, = {}) "DROP #{quote_column_name(column_name)}" end |
#remove_columns_sql(table_name, *column_names) ⇒ Object (protected)
113 114 115 |
# File 'lib/arjdbc/mysql/bulk_change_table.rb', line 113 def remove_columns_sql(table_name, *column_names) column_names.map {|column_name| remove_column_sql(table_name, column_name) } end |
#remove_index_sql(table_name, options = {}) ⇒ Object (protected)
122 123 124 125 |
# File 'lib/arjdbc/mysql/bulk_change_table.rb', line 122 def remove_index_sql(table_name, = {}) index_name = index_name_for_remove(table_name, ) "DROP INDEX #{index_name}" end |
#remove_timestamps_sql(table_name) ⇒ Object (protected)
131 132 133 |
# File 'lib/arjdbc/mysql/bulk_change_table.rb', line 131 def (table_name) [remove_column_sql(table_name, :updated_at), remove_column_sql(table_name, :created_at)] end |
#rename_column_sql(table_name, column_name, new_column_name) ⇒ Object
77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 |
# File 'lib/arjdbc/mysql/bulk_change_table.rb', line 77 def rename_column_sql(table_name, column_name, new_column_name) = {} if column = columns(table_name).find { |c| c.name == column_name.to_s } [:default] = column.default [:null] = column.null [:auto_increment] = (column.extra == "auto_increment") else raise ActiveRecordError, "No such column: #{table_name}.#{column_name}" end current_type = select_one("SHOW COLUMNS FROM #{quote_table_name(table_name)} LIKE '#{column_name}'", 'SCHEMA')["Type"] rename_column_sql = "CHANGE #{quote_column_name(column_name)} #{quote_column_name(new_column_name)} #{current_type}" (rename_column_sql, ) rename_column_sql end |
#supports_bulk_alter? ⇒ Boolean
12 |
# File 'lib/arjdbc/mysql/bulk_change_table.rb', line 12 def supports_bulk_alter?; true end |