通过Rails迁移删除数据库表列的语法是什么?
当前回答
有两种好方法:
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
其他回答
生成一个迁移以删除一个列,这样如果它被迁移(rake db:migrate),它应该删除该列。如果这个迁移被回滚(rake db:rollback),它应该将列添加回。
语法:
Remove_column:table_name,:column_name,:type
删除列,如果迁移回滚,也将列添加回。
例子:
remove_column :users, :last_name, :string
注意:如果跳过data_type,迁移将成功移除列,但如果回滚迁移,它将抛出一个错误。
步骤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
rails g migration RemoveXColumnFromY column_name:data_type
X =列名 Y =表名
EDIT
根据注释将RemoveXColumnToY更改为RemoveXColumnFromY -为迁移实际做的事情提供了更清晰的说明。
通过 Remove_column:table_name,:column_name 在迁移文件中
你可以在rails控制台中直接删除一个列: ActiveRecord:: Base。Remove_column:table_name,:column_name
给出下面的命令,它将自己添加到迁移文件中
rails g migration RemoveColumnFromModel
运行以上命令后,您可以检查迁移文件remove_column代码必须自己添加到那里
然后迁移数据库
rake db:migrate
推荐文章
- Rails:如何在Rails 4中引用CSS中的图像
- 如何使用RSpec的should_raise与任何类型的异常?
- 我看到VARCHAR(255)如此频繁地使用(而不是其他长度),有什么好的原因吗?
- 如何创建退出消息
- 忽略GEM,因为没有构建它的扩展
- Rails -嵌套包括活动记录?
- 在Gem::Specification.reset期间未解决的规格:
- 使用pgadmin连接到heroku数据库
- Delete_all vs destroy_all
- 双引号vs单引号
- 用any可以吗?'来检查数组是否为空?
- 我如何移动一个redis数据库从一个服务器到另一个?
- Rails获取“each”循环的索引
- 如何首次配置postgresql ?
- 数据库性能调优有哪些资源?