通过Rails迁移删除数据库表列的语法是什么?


当前回答

通过 Remove_column:table_name,:column_name 在迁移文件中

你可以在rails控制台中直接删除一个列: ActiveRecord:: Base。Remove_column:table_name,:column_name

其他回答

在rails 5中,你可以在终端中使用这个命令:

rails generate migration remove_COLUMNNAME_from_TABLENAME COLUMNNAME:DATATYPE

例如,从user表中删除access_level(string)列:

rails generate migration remove_access_level_from_users access_level:string

然后运行:

rake db:migrate

这样做;

rails g migration RemoveColumnNameFromTables column_name:类型

即rails g migration RemoveTitleFromPosts title:字符串

无论如何,最好考虑停机时间以及因为ActiveRecord在运行时缓存数据库列,所以如果你删除一列,它可能会导致异常,直到你的应用程序重新启动。

参考:强迁移

首先尝试使用以下命令创建一个迁移文件:

rails g migration RemoveAgeFromUsers age:string

然后在项目的根目录运行迁移命令:

rails db:migrate

简单地说,您可以删除列

remove_column :table_name, :column_name

例如,

remove_column :posts, :comment

Rails 4已经更新,因此可以在迁移中使用change方法来删除列,并且迁移将成功回滚。请阅读以下Rails 3应用程序警告:

Rails 3警告

请注意,当你使用这个命令时:

rails generate migration RemoveFieldNameFromTableName field_name:datatype

生成的迁移看起来像这样:

  def up
    remove_column :table_name, :field_name
  end

  def down
    add_column :table_name, :field_name, :datatype
  end

确保在从数据库表中删除列时不使用change方法(例如在Rails 3应用程序的迁移文件中不希望看到的内容):

  def change
    remove_column :table_name, :field_name
  end

Rails 3中的change方法在涉及remove_column时并不聪明,因此您将无法回滚此迁移。