Module: ForAlterStatements
- Included in:
- ActiveRecord::ConnectionAdapters::DepartureAdapter, ActiveRecord::ConnectionAdapters::Rails72DepartureAdapter, ActiveRecord::ConnectionAdapters::Rails80DepartureAdapter
- Defined in:
- lib/active_record/connection_adapters/for_alter.rb
Class Method Summary collapse
Instance Method Summary collapse
- #add_column_for_alter(table_name, column_name, type, options = {}) ⇒ Object
- #add_index_for_alter(table_name, column_name, options = {}) ⇒ Object
- #add_timestamps_for_alter(table_name, options = {}) ⇒ Object
-
#bulk_change_table(table_name, operations) ⇒ Object
:nodoc:.
- #change_column_for_alter(table_name, column_name, type, options = {}) ⇒ Object
- #remove_column_for_alter(_table_name, column_name, _type = nil, _options = {}) ⇒ Object
- #remove_columns_for_alter(table_name, *column_names, **options) ⇒ Object
- #remove_index_for_alter(table_name, column_name = nil, **options) ⇒ Object
- #remove_timestamps_for_alter(table_name, _options = {}) ⇒ Object
- #rename_column_for_alter(table_name, column_name, new_column_name) ⇒ Object
Class Method Details
.included(_) ⇒ Object
5 6 7 |
# File 'lib/active_record/connection_adapters/for_alter.rb', line 5 def included(_) STDERR.puts 'Including for_alter statements' end |
Instance Method Details
#add_column_for_alter(table_name, column_name, type, options = {}) ⇒ Object
77 78 79 80 81 |
# File 'lib/active_record/connection_adapters/for_alter.rb', line 77 def add_column_for_alter(table_name, column_name, type, = {}) td = create_table_definition(table_name) cd = td.new_column_definition(column_name, type, **) schema_creation.accept(ActiveRecord::ConnectionAdapters::AddColumnDefinition.new(cd)) end |
#add_index_for_alter(table_name, column_name, options = {}) ⇒ Object
54 55 56 57 58 |
# File 'lib/active_record/connection_adapters/for_alter.rb', line 54 def add_index_for_alter(table_name, column_name, = {}) index_definition, = (table_name, column_name, **) "ADD #{schema_creation.accept(index_definition)}" end |
#add_timestamps_for_alter(table_name, options = {}) ⇒ Object
66 67 68 69 70 71 |
# File 'lib/active_record/connection_adapters/for_alter.rb', line 66 def (table_name, = {}) [ add_column_for_alter(table_name, :created_at, :datetime, ), add_column_for_alter(table_name, :updated_at, :datetime, ) ] end |
#bulk_change_table(table_name, operations) ⇒ Object
:nodoc:
10 11 12 13 14 15 16 17 18 19 20 21 22 |
# File 'lib/active_record/connection_adapters/for_alter.rb', line 10 def bulk_change_table(table_name, operations) #:nodoc: sqls = operations.flat_map do |command, args| table = args.shift arguments = args method = :"#{command}_for_alter" raise "Unknown method called : #{method}(#{arguments.inspect})" unless respond_to?(method, true) public_send(method, table, *arguments) end.join(', ') execute("ALTER TABLE #{quote_table_name(table_name)} #{sqls}") end |
#change_column_for_alter(table_name, column_name, type, options = {}) ⇒ Object
24 25 26 27 28 29 30 31 32 33 34 35 36 37 |
# File 'lib/active_record/connection_adapters/for_alter.rb', line 24 def change_column_for_alter(table_name, column_name, type, = {}) column = column_for(table_name, column_name) type ||= column.sql_type = { default: column.default, null: column.null, comment: column.comment }.merge() td = create_table_definition(table_name) cd = td.new_column_definition(column.name, type, **) schema_creation.accept(ActiveRecord::ConnectionAdapters::ChangeColumnDefinition.new(cd, column.name)) end |
#remove_column_for_alter(_table_name, column_name, _type = nil, _options = {}) ⇒ Object
83 84 85 |
# File 'lib/active_record/connection_adapters/for_alter.rb', line 83 def remove_column_for_alter(_table_name, column_name, _type = nil, = {}) "DROP COLUMN #{quote_column_name(column_name)}" end |
#remove_columns_for_alter(table_name, *column_names, **options) ⇒ Object
87 88 89 |
# File 'lib/active_record/connection_adapters/for_alter.rb', line 87 def remove_columns_for_alter(table_name, *column_names, **) column_names.map { |column_name| remove_column_for_alter(table_name, column_name) } end |
#remove_index_for_alter(table_name, column_name = nil, **options) ⇒ Object
60 61 62 63 64 |
# File 'lib/active_record/connection_adapters/for_alter.rb', line 60 def remove_index_for_alter(table_name, column_name = nil, **) index_name = index_name_for_remove(table_name, column_name, ) "DROP INDEX #{quote_column_name(index_name)}" end |
#remove_timestamps_for_alter(table_name, _options = {}) ⇒ Object
73 74 75 |
# File 'lib/active_record/connection_adapters/for_alter.rb', line 73 def (table_name, = {}) [remove_column_for_alter(table_name, :updated_at), remove_column_for_alter(table_name, :created_at)] end |
#rename_column_for_alter(table_name, column_name, new_column_name) ⇒ Object
39 40 41 42 43 44 45 46 47 48 49 50 51 52 |
# File 'lib/active_record/connection_adapters/for_alter.rb', line 39 def rename_column_for_alter(table_name, column_name, new_column_name) column = column_for(table_name, column_name) = { default: column.default, null: column.null, auto_increment: column.auto_increment? } columns_sql = "SHOW COLUMNS FROM #{quote_table_name(table_name)} LIKE #{quote(column_name)}" current_type = exec_query(columns_sql, 'SCHEMA').first['Type'] td = create_table_definition(table_name) cd = td.new_column_definition(new_column_name, current_type, **) schema_creation.accept(ActiveRecord::ConnectionAdapters::ChangeColumnDefinition.new(cd, column.name)) end |