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


当前回答

rails g migration RemoveXColumnFromY column_name:data_type

X =列名 Y =表名

EDIT

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

其他回答

在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

change方法中的Remove_column将帮助您从表中删除列。

class RemoveColumn < ActiveRecord::Migration
  def change
    remove_column :table_name, :column_name, :data_type
  end
end

点击这个链接获取完整的参考:http://guides.rubyonrails.org/active_record_migrations.html

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

rails g migration RemoveAgeFromUsers age:string

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

rails db:migrate

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

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

rails g migration RemoveXColumnFromY column_name:data_type

X =列名 Y =表名

EDIT

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