change_column_default
data:image/s3,"s3://crabby-images/32bf4/32bf4df050cf45d5fe8734d63ff7e99017eb98db" alt="Extensive documentation Importance_4"
change_column_default(table_name, column_name, default_or_changes)
public
Sets a new default value for a column:
change_column_default(:suppliers, :qualification, 'new') change_column_default(:accounts, :authorized, 1)
Setting the default to nil effectively drops the default:
change_column_default(:users, :email, nil)
Passing a hash containing :from and :to will make this change reversible in migration:
change_column_default(:posts, :state, from: nil, to: "draft")
data:image/s3,"s3://crabby-images/1f051/1f051ca1d071cbb721478c88c8e4c481144619d6" alt="Default_avatar_30"
Implemented in database adapters
These methods are not implemented in the abstract classes. Instead, all database adapters implement these separately, if the feature is supported.
data:image/s3,"s3://crabby-images/2afdb/2afdb1842b857c4ddc6c4299cc2585f7d4f8d1c4" alt="Default_avatar_30"
How to set default value to NULL
To set default value to NULL you can use change_column method instead, for example:
change_column :suppliers, :qualification, :string, :default => nil
Just make sure you don’t change data type accidentally ;-)
data:image/s3,"s3://crabby-images/2afdb/2afdb1842b857c4ddc6c4299cc2585f7d4f8d1c4" alt="Default_avatar_30"
Not implented yet
According to this method’s source, change_column_default is not implemented as well as change_column
data:image/s3,"s3://crabby-images/85c40/85c40ef92a9128228ccd41a5cdd205d3464392f9" alt="Default_avatar_30"
change_column did the trick for me
Use change_column, and make sure to specify the datatype:
class ChangeUsers < ActiveRecord::Migration def up change_column :users, :is_vote_reminder, :boolean, :default => true end end