Class: ActiveRecord::Migration::Compatibility::V5_1

Inherits:
V5_2 show all
Defined in:
activerecord/lib/active_record/migration/compatibility.rb

Direct Known Subclasses

V5_0

Instance Method Summary collapse

Methods inherited from V5_2

#add_timestamps, #change_table, #create_join_table

Methods inherited from V6_0

#add_reference, #change_table, #create_join_table

Methods inherited from V6_1

#add_column

Instance Method Details

#change_column(table_name, column_name, type, **options) ⇒ Object


203
204
205
206
207
208
209
210
211
212
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 203

def change_column(table_name, column_name, type, **options)
  if connection.adapter_name == "PostgreSQL"
    super(table_name, column_name, type, **options.except(:default, :null, :comment))
    connection.change_column_default(table_name, column_name, options[:default]) if options.key?(:default)
    connection.change_column_null(table_name, column_name, options[:null], options[:default]) if options.key?(:null)
    connection.change_column_comment(table_name, column_name, options[:comment]) if options.key?(:comment)
  else
    super
  end
end

#create_table(table_name, **options) ⇒ Object


214
215
216
217
218
219
220
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 214

def create_table(table_name, **options)
  if connection.adapter_name == "Mysql2"
    super(table_name, options: "ENGINE=InnoDB", **options)
  else
    super
  end
end