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

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

Direct Known Subclasses

V5_0

Instance Method Summary collapse

Methods inherited from V5_2

#add_timestamps

Methods inherited from V6_0

#add_reference

Methods inherited from V6_1

#add_column

Methods inherited from V7_0

#add_column, #add_foreign_key, #add_index, #add_reference, #change_column_null, #disable_extension, #rename_table

Instance Method Details

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



316
317
318
319
320
321
322
323
324
325
# File 'lib/active_record/migration/compatibility.rb', line 316

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



327
328
329
330
331
332
333
# File 'lib/active_record/migration/compatibility.rb', line 327

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