通过Rails迁移删除数据库表列的语法是什么?
当前回答
这样做;
rails g migration RemoveColumnNameFromTables column_name:类型
即rails g migration RemoveTitleFromPosts title:字符串
无论如何,最好考虑停机时间以及因为ActiveRecord在运行时缓存数据库列,所以如果你删除一列,它可能会导致异常,直到你的应用程序重新启动。
参考:强迁移
其他回答
删除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的快速参考指南,可以在这里找到。
生成一个迁移以删除一个列,这样如果它被迁移(rake db:migrate),它应该删除该列。如果这个迁移被回滚(rake db:rollback),它应该将列添加回。
语法:
Remove_column:table_name,:column_name,:type
删除列,如果迁移回滚,也将列添加回。
例子:
remove_column :users, :last_name, :string
注意:如果跳过data_type,迁移将成功移除列,但如果回滚迁移,它将抛出一个错误。
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(它们都是相同的)
....然后你就可以去比赛了!
步骤1:创建迁移
rails g migration remove_column_name_from_table
步骤2:更改刚刚创建的文件迁移中的代码
Rails版本< 3
def change
remove_column :table_name, :column_name, :datatype
end
Rails版本>= 3
def change
remove_column :table_name, :column_name
end
3 .迁移
rake db:migrate
你可以尝试以下方法:
remove_column :table_name, :column_name
(官方文档)
推荐文章
- 确定ActiveRecord对象是否为New
- Rails中的OO设计:在哪里放置东西
- 如何在Heroku上重新启动rails服务器?
- respond_to块如何工作?
- 使用{merge: true}设置的Firestore与更新之间的差异
- mysql_connect():[2002]没有这样的文件或目录(试图通过unix:///tmp/mysql.sock连接)在
- 使用电子邮件地址为主键?
- 给定一个类,查看实例是否有方法(Ruby)
- rails局部模板中的可选局部变量:如何退出(defined?foo)混乱?
- MongoDB在v4之前不兼容ACID意味着什么?
- 在日历应用程序中建模重复事件的最佳方法是什么?
- Ruby Bundle Symbol not found: _SSLv2_client_method (LoadError)
- 第一次设计数据库:我是否过度设计了?
- 如何创建一个私有类方法?
- rails耙任务是否提供对ActiveRecord模型的访问?