change_column
data:image/s3,"s3://crabby-images/02b7a/02b7a1d5dc3f5678ca812feecab5ac4576dcbd86" alt="Very extensive documentation Importance_5"
change_column(table_name, column_name, type, options = {})
public
Changes the column’s definition according to the new options. See TableDefinition#column for details of the options you can use.
change_column(:suppliers, :name, :string, limit: 80) change_column(:accounts, :description, :text)
data:image/s3,"s3://crabby-images/fd96f/fd96f77a2816c0aaafaf0761deffaa7651dc84de" alt="Default_avatar_30"
to set NULL => NO
use :null => false
change_column :my_table, :my_column, :integer, :default => 0, :null => false
data:image/s3,"s3://crabby-images/ef4fa/ef4fac46617b97cf8c90114a9203dc9037f58710" alt="Default_avatar_30"
null to no effects
change_column will not query to replace the null values when you change null to false, even if you have a default set. This may cause the query to fail (may depend on the database used).
change_column_null will optionally take a value to replace nulls if you are setting null to false. If you want to set a default and disallow nulls you likely can’t do both in one change_column call.
data:image/s3,"s3://crabby-images/fd96f/fd96f77a2816c0aaafaf0761deffaa7651dc84de" alt="Default_avatar_30"
Changing to MySql:BIGINT
I can change a column type from INT to BIGINT with this command:
change_column :my_table, :my_column, :bigint
data:image/s3,"s3://crabby-images/975e9/975e9e72c34b215b3640317d693cb1a16ffc4d1e" alt="Default_avatar_30"
data:image/s3,"s3://crabby-images/263f4/263f41fc70bffd0e2446ce647fc2ca77bc0b8f95" alt="Default_avatar_30"
Destroying Data
As far as I can tell, at least on a migration of a column from an integer to a decimal, this does not get rid of existing data.
data:image/s3,"s3://crabby-images/47bc5/47bc565e28bf97c61479d041cdd7b422c935e005" alt="Default_avatar_30"
Will this method get rid of existing data?
Will this method get rid of existing data?
data:image/s3,"s3://crabby-images/783e1/783e14be15a93448547eec6c3c6e708036387956" alt="Default_avatar_30"
On destroying data
Reply to tvle83 and pgmcgee: the destructiveness of this method depends on your database. Some databases are better at converting between disparate types than others. For example, when changing a column from a numeric type to a string type, some databases drop the data where others will turn the numbers into their string representations.
Essentially, YMMV.