From 9477f4372fac1a18aad6fbce249a1bfc03e0b61f Mon Sep 17 00:00:00 2001 From: Mauro George Date: Sun, 1 Jun 2014 09:55:11 -0300 Subject: Create Changing Columns on migrations guides [ci skip] --- guides/source/migrations.md | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) (limited to 'guides') diff --git a/guides/source/migrations.md b/guides/source/migrations.md index 6742c05946..221251adf4 100644 --- a/guides/source/migrations.md +++ b/guides/source/migrations.md @@ -415,6 +415,28 @@ end removes the `description` and `name` columns, creates a `part_number` string column and adds an index on it. Finally it renames the `upccode` column. +### Changing Columns + +Like the `remove_column` and `add_column` Rails provides the `change_column`. + +```ruby +change_column :products, :part_number, :text +``` + +This changes the column part_number on products table to be a text. + +Besides the `change_column`, the `change_column_null` and +`change_column_default` are used specifically to change the null and default +values of a column. + +```ruby +change_column_null :products, :name, false +change_column_default :products, :approved, false +``` + +This sets name on products to a NOT NULL column and the default value +of approved as false. + ### When Helpers aren't Enough If the helpers provided by Active Record aren't enough you can use the `execute` -- cgit v1.2.3