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


当前回答

remove_column :table_name, :column_name

例如:

remove_column :users, :hobby

从用户表中删除嗜好列。

其他回答

这里还有一个来自rails控制台的例子

ActiveRecord::迁移。remove_column (: table_name column_name):

简单地说,您可以删除列

remove_column :table_name, :column_name

例如,

remove_column :posts, :comment
rails g migration RemoveXColumnFromY column_name:data_type

X =列名 Y =表名

EDIT

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

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

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

这样做;

rails g migration RemoveColumnNameFromTables column_name:类型

即rails g migration RemoveTitleFromPosts title:字符串

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

参考:强迁移