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


当前回答

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

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

其他回答

删除RAILS 5应用程序的列

rails g migration Remove<Anything>From<TableName> [columnName:type]

上面的命令在db/migrate目录中生成一个迁移文件。Snippet blow是Rails生成器生成的从表中删除列的示例之一,

class RemoveAgeFromUsers < ActiveRecord::Migration
  def up
    remove_column :users, :age
  end
  def down
    add_column :users, :age, :integer
  end
end

我还做了一个Rails的快速参考指南,可以在这里找到。

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

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

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

你可以尝试以下方法:

remove_column :table_name, :column_name

(官方文档)

您可以使用rails迁移命令

rails generate migration RemoveColumnNameFromTableName column_name:column_type

然后你可以迁移数据库:

rails db:migrate