在新的首选方法中,只有一个方法似乎添加了一列。这是否意味着您不需要一个方法来删除列?
# the old way
class AddNameToPerson < ActiveRecord::Migration
def up
add_column :persons, :name, :string
end
def down
remove_column :person, :name
end
end
# the new prefered way
class AddNameToPerson < ActiveRecord::Migration
def change
add_column :persons, :name, :string
end
end发布于 2013-03-09 18:20:00
这就是Rails 3.1和更高版本的魔力所在。Rails知道如何迁移数据库,并在迁移回滚时反转数据库,而无需编写单独的down方法。
Rails跟踪迁移。因此,当您使用roll back时,它将具有用于撤销迁移添加的更改的实现。前面我们使用了两个方法up和down。在Rails3.1和更高版本中,他们将迁移更改为使用change方法。
在add_coulmn的情况下,反向方法是remove_column,其他方法也是如此。使用跟踪的详细信息,它将调用相应的操作。因此您不需要两个方法(up和down)。您可以看到change方法支持的方法:here。如果您有其他方法,则需要使用up和down。
如果您对使用change方法感到困惑,那么我建议您使用up和down。一旦完成了迁移,您就可以开始使用change方法了。
发布于 2013-03-09 18:21:08
您是对的,您不需要单独的方法来删除列。
您甚至可以尝试'rake db:rollback‘,然后再次尝试'rake db:migrate’,如果没有任何数据可丢失的话。
它工作得很完美。:)
https://stackoverflow.com/questions/15309564
复制相似问题