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


当前回答

rails g migration RemoveXColumnFromY column_name:data_type

X =列名 Y =表名

EDIT

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

其他回答

给出下面的命令,它将自己添加到迁移文件中

rails g migration RemoveColumnFromModel

运行以上命令后,您可以检查迁移文件remove_column代码必须自己添加到那里

然后迁移数据库

rake db:migrate

简单地说,您可以删除列

remove_column :table_name, :column_name

例如,

remove_column :posts, :comment
remove_column :table_name, :column_name

例如:

remove_column :users, :hobby

从用户表中删除嗜好列。

在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

你可以尝试以下方法:

remove_column :table_name, :column_name

(官方文档)