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


当前回答

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

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

其他回答

有两种好方法:

remove_column

你可以简单地使用remove_column,像这样:

remove_column :users, :first_name

如果您只需要对模式进行单个更改,那么这是很好的。

change_table块

你也可以使用change_table块来做到这一点,像这样:

change_table :users do |t|
  t.remove :first_name
end

我更喜欢这个,因为我发现它更容易读懂,你可以一次做几个改变。

下面是支持的change_table方法的完整列表:

http://apidock.com/rails/ActiveRecord/ConnectionAdapters/SchemaStatements/change_table

你可以尝试以下方法:

remove_column :table_name, :column_name

(官方文档)

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

rails g migration RemoveColumnFromModel

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

然后迁移数据库

rake db:migrate

在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控制台中运行即可

ActiveRecord::Base.connection.remove_column("table_name", :column_name, :its_data_type)

or

TableName.find_by_sql(“ALTER TABLE table_name DROP column_name”)