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


当前回答

remove_column :table_name, :column_name

例如:

remove_column :users, :hobby

从用户表中删除嗜好列。

其他回答

删除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的快速参考指南,可以在这里找到。

从表中删除列只需简单的3个步骤如下:

写这个命令

Rails迁移remove_column_from_table_name

在终端上运行此命令后,使用此名称和时间戳创建的文件(remove_column from_table_name)。

然后转到这个文件。

里面的文件你必须写 Remove_column:table_name,:column_name 最后转到控制台,然后执行 rake db: migrate

你可以尝试以下方法:

remove_column :table_name, :column_name

(官方文档)

remove_column :table_name, :column_name

例如:

remove_column :users, :hobby

从用户表中删除嗜好列。

有两种好方法:

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