Class: ActiveRecord::Schema
| Relationships & Source Files | |
| Namespace Children | |
|
Modules:
| |
| Super Chains via Extension / Inclusion / Inheritance | |
|
Class Chain:
self,
Migration::Current,
Migration
|
|
|
Instance Chain:
|
|
| Inherits: |
ActiveRecord::Migration::Current
|
| Defined in: | activerecord/lib/active_record/schema.rb |
Overview
Allows programmers to programmatically define a schema in a portable DSL. This means you can define tables, indexes, etc. without using SQL directly, so your applications can more easily support multiple databases.
Usage:
ActiveRecord::Schema[7.0].define do
create_table : do |t|
t.string :name, null: false
end
add_index :, :name, :unique
create_table :posts do |t|
t.integer :, null: false
t.string :subject
t.text :body
t.boolean :private, default: false
end
add_index :posts, :
end
Schema is only supported by database adapters that also support migrations, the two features being very similar.
Constant Summary
Migration - Inherited
Class Attribute Summary
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
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, .load_schema!, .pending_migrations, .respond_to_missing?, .check_pending_migrations, .inherited, .maintain_test_schema!, .method_missing, .nearest_delegate, .valid_version_format? | |
Instance Attribute Summary
Migration - Inherited
| #name, #reverting?, | |
| #verbose | Alias for class attribute |
| #version | |
Instance Method Summary
Definition - Included
Migration::Current - Inherited
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?, #respond_to_missing?, #disable_ddl_transaction, | |
| #table_name_options | Builds a hash for use in 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
Class Method Details
.[](version)
[ GitHub ]# File 'activerecord/lib/active_record/schema.rb', line 70
def self.[](version) @class_for_version ||= {} @class_for_version[version] ||= Class.new(Migration::Compatibility.find(version)) do include Definition end end