Class: ActiveRecord::Migration::Compatibility::V4_2
Relationships & Source Files | |
Namespace Children | |
Modules:
| |
Super Chains via Extension / Inclusion / Inheritance | |
Class Chain:
self,
V5_0 ,
V5_1 ,
V5_2 ,
V6_0 ,
V6_1 ,
V7_0 ,
V7_1 ,
::ActiveRecord::Migration::Current ,
::ActiveRecord::Migration
|
|
Instance Chain:
|
|
Inherits: |
ActiveRecord::Migration::Compatibility::V5_0
|
Defined in: | activerecord/lib/active_record/migration/compatibility.rb |
Constant Summary
::ActiveRecord::Migration
- Inherited
Class Attribute Summary
::ActiveRecord::Migration
- Inherited
.verbose | Specifies if migrations will write the actions they are taking to the console as they happen, along with benchmarks describing how long each step took. |
.any_schema_needs_update?, .delegate, .disable_ddl_transaction |
Class Method Summary
::ActiveRecord::Migration
- Inherited
.[], | |
.check_all_pending! | Raises |
.current_version, | |
.disable_ddl_transaction! | Disable the transaction wrapping this migration. |
.load_schema_if_pending!, .migrate, .new, .db_configs_in_current_env, .env, .pending_migrations, .check_pending_migrations, .inherited, .maintain_test_schema!, .method_missing, .nearest_delegate, .valid_version_format? |
Instance Attribute Summary
::ActiveRecord::Migration
- Inherited
#name, #reverting?, | |
#verbose | Alias for class attribute ActiveRecord::Migration.verbose |
#version |
Instance Method Summary
-
#add_belongs_to(table_name, ref_name, **options)
Alias for #add_reference.
- #add_reference(table_name, ref_name, **options) (also: #add_belongs_to)
- #add_timestamps(table_name, **options)
- #index_exists?(table_name, column_name, **options) ⇒ Boolean
- #remove_index(table_name, column_name = nil, **options)
- #compatible_table_definition(t) private
- #index_name_for_remove(table_name, column_name, options) private
V5_0
- Inherited
#add_belongs_to | Alias for V5_0#add_reference. |
#add_column, #add_reference, #create_join_table, #create_table, #compatible_table_definition |
V5_1
- Inherited
V5_2
- Inherited
V6_0
- Inherited
V6_1
- Inherited
V7_0
- Inherited
V7_0::LegacyIndexName
- Included
::ActiveRecord::Migration::Current
- Inherited
::ActiveRecord::Migration
- Inherited
#announce, #connection, #connection_pool, #copy, #down, #exec_migration, #execution_strategy, #method_missing, | |
#migrate | Execute this migration in the named direction. |
#next_migration_number | Determines the version number of the next migration. |
#proper_table_name | Finds the correct table name given an Active Record object. |
#reversible | Used to specify an operation that can be run in one direction or another. |
#revert | Reverses the migration commands for the given block and the given migrations. |
#run | Runs the given migration classes. |
#say | Takes a message argument and outputs it as is. |
#say_with_time | Outputs text along with how long it took to run its block. |
#suppress_messages | Takes a block as an argument and suppresses any output generated by the block. |
#up, | |
#up_only | Used to specify an operation that is only run when migrating up (for example, populating a new column with its initial values). |
#write, #command_recorder, #execute_block, #format_arguments, #internal_option?, #disable_ddl_transaction, | |
#table_name_options | Builds a hash for use in ActiveRecord::Migration#proper_table_name using the Active Record object’s table_name prefix and suffix. |
Constructor Details
This class inherits a constructor from ActiveRecord::Migration
Dynamic Method Handling
This class handles dynamic methods through the method_missing method in the class ActiveRecord::Migration
Instance Method Details
#add_belongs_to(table_name, ref_name, **options)
Alias for #add_reference.
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 435
alias :add_belongs_to :add_reference
#add_reference(table_name, ref_name, **options) Also known as: #add_belongs_to
[ GitHub ]# File 'activerecord/lib/active_record/migration/compatibility.rb', line 431
def add_reference(table_name, ref_name, ** ) [:index] ||= false super end
#add_timestamps(table_name, **options)
[ GitHub ]# File 'activerecord/lib/active_record/migration/compatibility.rb', line 437
def (table_name, ** ) [:null] = true if [:null].nil? super end
#compatible_table_definition(t) (private)
[ GitHub ]# File 'activerecord/lib/active_record/migration/compatibility.rb', line 459
def compatible_table_definition(t) class << t prepend TableDefinition end super end
#index_exists?(table_name, column_name, **options) ⇒ Boolean
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 442
def index_exists?(table_name, column_name, ** ) column_names = Array(column_name).map(&:to_s) [:name] = if [:name].present? [:name].to_s else connection.index_name(table_name, column: column_names) end super end
#index_name_for_remove(table_name, column_name, options) (private)
[ GitHub ]# File 'activerecord/lib/active_record/migration/compatibility.rb', line 466
def index_name_for_remove(table_name, column_name, ) index_name = connection.index_name(table_name, column_name || ) unless connection.index_name_exists?(table_name, index_name) if .key?(:name) = .except(:column) index_name_without_column = connection.index_name(table_name, ) if connection.index_name_exists?(table_name, index_name_without_column) return index_name_without_column end end raise ArgumentError, "Index name '#{index_name}' on table '#{table_name}' does not exist" end index_name end
#remove_index(table_name, column_name = nil, **options)
[ GitHub ]# File 'activerecord/lib/active_record/migration/compatibility.rb', line 453
def remove_index(table_name, column_name = nil, ** ) [:name] = index_name_for_remove(table_name, column_name, ) super end