add_column
data:image/s3,"s3://crabby-images/02b7a/02b7a1d5dc3f5678ca812feecab5ac4576dcbd86" alt="Very extensive documentation Importance_5"
add_column(table_name, column_name, type, options = {})
public
Adds a new column to the named table. See TableDefinition#column for details of the options you can use.
data:image/s3,"s3://crabby-images/f5c45/f5c45d5f4605f8efaea75764fdd78de5b53af286" alt="Default_avatar_30"
data:image/s3,"s3://crabby-images/cb373/cb3733c4de0686a8d5815edc56d99b7adacdde6c" alt="Default_avatar_30"
script/generate syntax
To add a post_id field to a comments table, run this:
script\generate migration add_post_id_to_comment post_id:integer
See that it´s not the table name(plural), but the model name(singular),<br /> and post_id:references, does not works like in create_table.
This is the generated migration:
class AddPostIdToComment < ActiveRecord::Migration def self.up add_column :comments, :post_id, :integer end def self.down remove_column :comments, :post_id end end
data:image/s3,"s3://crabby-images/048b2/048b29dc3748c6bc02fc4e1c65988259261c0c85" alt="Default_avatar_30"
Options
Available options are (none of these exists by default):
* :limit - Requests a maximum column length. This is number of characters for :string and :text columns and number of bytes for :binary and :integer columns. * :default - The column‘s default value. Use nil for NULL. * :null - Allows or disallows NULL values in the column. This option could have been named :null_allowed. * :precision - Specifies the precision for a :decimal column. * :scale - Specifies the scale for a :decimal column.
data:image/s3,"s3://crabby-images/83665/836652e0ec03ab7d47704e3c61710fe64bc5cb34" alt="Default_avatar_30"
:null => false
To not allow a column to have a NULL value, pass :null => false. Seems silly, but that’s it.
data:image/s3,"s3://crabby-images/9fb04/9fb042dd6b57365cfdbcae80e30a496889722dbc" alt="Default_avatar_30"
data:image/s3,"s3://crabby-images/0009b/0009b9dff67d83e6398443d19673d199879a1878" alt="Default_avatar_30"
Redirect...
See ActiveRecord::ConnectionAdapters::TableDefinition#column for details of the options you can use.
data:image/s3,"s3://crabby-images/d18a3/d18a3128a61148dcfd4b4b8553aaa50689d66f8c" alt="Default_avatar_30"
script/generate can take table name
As far as I can tell script/generate will happily take the plural table name, at least in Rails 2.3.