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


当前回答

你可以尝试以下方法:

remove_column :table_name, :column_name

(官方文档)

其他回答

简单地说,您可以删除列

remove_column :table_name, :column_name

例如,

remove_column :posts, :comment

要从表中删除列,您必须运行以下迁移:

rails g migration remove_column_name_from_table_name column_name:data_type

然后执行命令:

rake db:migrate

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

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

rails g migration RemoveXColumnFromY column_name:data_type

X =列名 Y =表名

EDIT

根据注释将RemoveXColumnToY更改为RemoveXColumnFromY -为迁移实际做的事情提供了更清晰的说明。

步骤1:创建迁移

  rails g migration remove_column_name_from_table

步骤2:更改刚刚创建的文件迁移中的代码

Rails版本< 3

  def change
    remove_column :table_name, :column_name, :datatype
  end

Rails版本>= 3

  def change
    remove_column :table_name, :column_name
  end

3 .迁移

rake db:migrate