通过Rails迁移删除数据库表列的语法是什么?
当前回答
这里还有一个来自rails控制台的例子
ActiveRecord::迁移。remove_column (: table_name column_name):
其他回答
Rails 4已经更新,因此可以在迁移中使用change方法来删除列,并且迁移将成功回滚。请阅读以下Rails 3应用程序警告:
Rails 3警告
请注意,当你使用这个命令时:
rails generate migration RemoveFieldNameFromTableName field_name:datatype
生成的迁移看起来像这样:
def up
remove_column :table_name, :field_name
end
def down
add_column :table_name, :field_name, :datatype
end
确保在从数据库表中删除列时不使用change方法(例如在Rails 3应用程序的迁移文件中不希望看到的内容):
def change
remove_column :table_name, :field_name
end
Rails 3中的change方法在涉及remove_column时并不聪明,因此您将无法回滚此迁移。
步骤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 RemoveColumnFromModel
运行以上命令后,您可以检查迁移文件remove_column代码必须自己添加到那里
然后迁移数据库
rake db:migrate
首先尝试使用以下命令创建一个迁移文件:
rails g migration RemoveAgeFromUsers age:string
然后在项目的根目录运行迁移命令:
rails db:migrate
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
推荐文章
- 如何记录Ruby代码?
- 如何检查一个表是否存在于给定的模式中
- Ruby:包含的反义词是什么?Ruby数组?
- 想要在Rails中找到没有关联记录的记录
- 如何在SQL Server Management Studio中查看查询历史
- helper和helper_method做什么?
- 如何回滚只是一个步骤使用耙db:迁移
- 在Ruby中,proc和lambda有什么区别?
- 如何传递参数到一个Rake任务与环境在Rails?
- 获取当前正在执行的方法的名称
- 如何在Rails中计算相对时间?
- 如何在Rails迁移中将可空列更改为不可空列?
- 如何创建数据库的MongoDB转储?
- 在Ruby中使用范围填充数组的正确方法
- “for”和“each”在Ruby中