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


当前回答

rails g migration RemoveXColumnFromY column_name:data_type

X =列名 Y =表名

EDIT

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

其他回答

在rails4应用中,也可以使用change方法删除列。第三个参数是data_type,在可选的参数中可以给出选项。它在文档中的“可用转换”部分中有点隐藏。

class RemoveFieldFromTableName < ActiveRecord::Migration
  def change
    remove_column :table_name, :field_name, :data_type, {}
  end
end

对于较旧版本的Rails

ruby script/generate migration RemoveFieldNameFromTableName field_name:datatype

适用于Rails 3及更高版本

rails generate migration RemoveFieldNameFromTableName field_name:datatype

Rails 5和6的清晰和简单的说明

警告:您将丢失数据。 警告:下面的指令是针对普通迁移的。对于复杂的迁移,例如数百万行,读/写dbs,集群,这个建议不适合你:


1. 创建迁移

在终端运行如下命令:

rails生成迁移remove_fieldname_from_tablename fieldname:fieldtype(根据约定,表名为复数形式。请在这里查看文档。)

示例:rails g migration RemoveAcceptedFromQuotes accepted:boolean

2. 检查迁移

# db/migrate/20190122035000_remove_accepted_from_quotes.rb
class RemoveAcceptedFromQuotes < ActiveRecord::Migration[5.2]
  # with rails 5.2 you don't need to add a separate "up" and "down" method.
  def change
    remove_column :quotes, :accepted, :boolean
  end
end

3.运行迁移

Rake db:migrate or rails db:migrate(它们都是相同的)

....然后你就可以去比赛了!

简单地说,您可以删除列

remove_column :table_name, :column_name

例如,

remove_column :posts, :comment

有两种好方法:

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