如何向通过迁移已经存在的列添加默认值?

我能找到的所有文档都向您展示了如何在列不存在的情况下做到这一点,但在这种情况下它存在。


当前回答

对于Rails 4+,请使用change_column_default

def change
  change_column_default :table, :column, value
end

其他回答

你应该这样做:

change_column :users, :admin, :boolean, :default => false

但是有些数据库(如PostgreSQL)不会更新之前创建的行字段,因此请确保在迁移时也手动更新字段。

你可以这样做:

class Profile < ActiveRecord::Base
  before_save :set_default_val

  def set_default_val
    self.send_updates = 'val' unless self.send_updates
  end
end

编辑:…但显然这是新手犯的错误!

* * Rails 4。X + * *

从Rails 4开始,你不能生成一个迁移,将一个列添加到一个默认值的表中, 以下步骤将新列添加到默认值为true或false的现有表中。

1. 运行migration from命令行以添加新列

$ rails generate migration add_columnname_to_tablename columnname:boolean

上面的命令将在表中添加一个新列。

2. 通过编辑创建的新迁移文件,将新列值设置为TRUE/FALSE。

class AddColumnnameToTablename < ActiveRecord::Migration
  def change
    add_column :table_name, :column_name, :boolean, default: false
  end
end

* * 3。要对应用程序数据库表进行更改,请在终端**中运行以下命令

$ rake db:migrate
change_column_default :employees, :foreign, false

使用def change意味着您应该编写可逆的迁移。而且change_column是不可逆的。你可以向上但不能向下,因为change_column是不可逆的。

相反,尽管它可能是额外的几行,但您应该使用def up和def down

因此,如果您有一个没有默认值的列,那么您应该这样做来添加一个默认值。

def up
  change_column :users, :admin, :boolean, default: false
end

def down
  change_column :users, :admin, :boolean, default: nil
end

或者如果您想更改现有列的默认值。

def up
  change_column :users, :admin, :boolean, default: false
end

def down
  change_column :users, :admin, :boolean, default: true
end