1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00

Adds 'References' section to migrations guide, sorts column modifiers lists and adds 'collation' option documentation

* Creates 'References' section in ActiveRecord migrations guide and moves all 'add_reference' specific column modifiers information into this section
* Adds the :collation option to the list of column modifiers section of the ActiveRecord migrations guide
* Adds the :collation option to the documentation of ConnectionAdapters::SchemaStatements#add_column
* Improves both lists of column modifiers by copying from one another
* Sorts the lists of column modifiers alphabetically
This commit is contained in:
Eike Send 2020-01-09 14:31:29 +01:00
parent 2ab30a5fff
commit 9016e22105
2 changed files with 74 additions and 14 deletions

View file

@ -518,6 +518,8 @@ module ActiveRecord
# Add a new +type+ column named +column_name+ to +table_name+. # Add a new +type+ column named +column_name+ to +table_name+.
# #
# See {ActiveRecord::ConnectionAdapters::TableDefinition.column}[rdoc-ref:ActiveRecord::ConnectionAdapters::TableDefinition#column].
#
# The +type+ parameter is normally one of the migrations native types, # The +type+ parameter is normally one of the migrations native types,
# which is one of the following: # which is one of the following:
# <tt>:primary_key</tt>, <tt>:string</tt>, <tt>:text</tt>, # <tt>:primary_key</tt>, <tt>:string</tt>, <tt>:text</tt>,
@ -530,12 +532,17 @@ module ActiveRecord
# agnostic and should usually be avoided. # agnostic and should usually be avoided.
# #
# Available options are (none of these exists by default): # Available options are (none of these exists by default):
# * <tt>:comment</tt> -
# Specifies the comment for the column. This option is ignored by some backends.
# * <tt>:collation</tt> -
# Specifies the collation for a <tt>:string</tt> or <tt>:text</tt> column.
# If not specified, the column will have the same collation as the table.
# * <tt>:default</tt> -
# The column's default value. Use +nil+ for +NULL+.
# * <tt>:limit</tt> - # * <tt>:limit</tt> -
# Requests a maximum column length. This is the number of characters for a <tt>:string</tt> column # Requests a maximum column length. This is the number of characters for a <tt>:string</tt> column
# and number of bytes for <tt>:text</tt>, <tt>:binary</tt>, <tt>:blob</tt>, and <tt>:integer</tt> columns. # and number of bytes for <tt>:text</tt>, <tt>:binary</tt>, <tt>:blob</tt>, and <tt>:integer</tt> columns.
# This option is ignored by some backends. # This option is ignored by some backends.
# * <tt>:default</tt> -
# The column's default value. Use +nil+ for +NULL+.
# * <tt>:null</tt> - # * <tt>:null</tt> -
# Allows or disallows +NULL+ values in the column. # Allows or disallows +NULL+ values in the column.
# * <tt>:precision</tt> - # * <tt>:precision</tt> -

View file

@ -251,7 +251,9 @@ class AddUserRefToProducts < ActiveRecord::Migration[6.0]
end end
``` ```
This migration will create a `user_id` column and appropriate index. This migration will create a `user_id` column, [references](#references) are a
shorthand for creating columns, indexes, foreign keys or even polymorphic
association columns.
There is also a generator which will produce join tables if `JoinTable` is part of the name: There is also a generator which will produce join tables if `JoinTable` is part of the name:
@ -347,8 +349,7 @@ create_table :products do |t|
end end
``` ```
which creates a `products` table with a column called `name` (and as discussed which creates a `products` table with a column called `name`.
below, an implicit `id` column).
By default, `create_table` will create a primary key called `id`. You can change By default, `create_table` will create a primary key called `id`. You can change
the name of the primary key with the `:primary_key` option (don't forget to the name of the primary key with the `:primary_key` option (don't forget to
@ -364,6 +365,16 @@ end
will append `ENGINE=BLACKHOLE` to the SQL statement used to create the table. will append `ENGINE=BLACKHOLE` to the SQL statement used to create the table.
An index can be created on the columns created within the `create_table` block
by passing true or an options hash to the `:index` option:
```ruby
create_table :users do |t|
t.string :name, index: true
t.string :email, index: { unique: true, name: 'unique_emails' }
end
```
Also you can pass the `:comment` option with any description for the table Also you can pass the `:comment` option with any description for the table
that will be stored in database itself and can be viewed with database administration that will be stored in database itself and can be viewed with database administration
tools, such as MySQL Workbench or PgAdmin III. It's highly recommended to specify tools, such as MySQL Workbench or PgAdmin III. It's highly recommended to specify
@ -469,23 +480,65 @@ example, this would make your migration irreversible.
Column modifiers can be applied when creating or changing a column: Column modifiers can be applied when creating or changing a column:
* `limit` Sets the maximum size of the `string/text/binary/integer` fields. * `comment` Adds a comment for the column.
* `precision` Defines the precision for the `decimal` fields, representing the * `collation` Specifies the collation for a `string` or `text` column.
total number of digits in the number.
* `scale` Defines the scale for the `decimal` fields, representing the
number of digits after the decimal point.
* `polymorphic` Adds a `type` column for `belongs_to` associations.
* `null` Allows or disallows `NULL` values in the column.
* `default` Allows to set a default value on the column. Note that if you * `default` Allows to set a default value on the column. Note that if you
are using a dynamic value (such as a date), the default will only be calculated are using a dynamic value (such as a date), the default will only be calculated
the first time (i.e. on the date the migration is applied). the first time (i.e. on the date the migration is applied). Use `nil` for `NULL`.
* `comment` Adds a comment for the column. * `limit` Sets the maximum number of characters for a `string` column
and the maximum number of bytes for `text/binary/integer` columns.
* `null` Allows or disallows `NULL` values in the column.
* `precision` Specifies the precision for `decimal/numeric/datetime/time` columns.
* `scale` Specifies the scale for the `decimal` and `numeric` columns,
representing the number of digits after the decimal point.
NOTE: For `add_column` or `change_column` there is no option for adding indexes.
They need to be added separately using `add_index`.
Some adapters may support additional options; see the adapter specific API docs Some adapters may support additional options; see the adapter specific API docs
for further information. for further information.
NOTE: `null` and `default` cannot be specified via command line. NOTE: `null` and `default` cannot be specified via command line.
### References
The `add_reference` method allows the creation of an appropriately named column.
```ruby
add_reference :users, :role
```
This migration will create a `role_id` column in the users table. It creates an
index for this column as well, unless explicitly told not with the
`index: false` option:
```ruby
add_reference :users, :role, index: false
```
The method `add_belongs_to` is an alias of `add_reference`.
```ruby
add_belongs_to :taggings, :taggable, polymorphic: true
```
The polymorphic option will create two columns on the taggings table which can
be used for polymorphic assocations: `taggable_type` and `taggable_id`.
A foreign key can be created with the the `foreign_key` option.
```ruby
add_reference :users, :role, foreign_key: true
```
For more `add_reference` options, visit the [API documentation](https://api.rubyonrails.org/classes/ActiveRecord/ConnectionAdapters/SchemaStatements.html#method-i-add_reference).
References can also be removed:
```ruby
remove_reference :products, :user, foreign_key: true, index: false
```
### Foreign Keys ### Foreign Keys
While it's not required you might want to add foreign key constraints to While it's not required you might want to add foreign key constraints to