我有一个迁移文件db\migrate\20100905201547_create_blocks.rb。
如何具体回滚该迁移文件?
我有一个迁移文件db\migrate\20100905201547_create_blocks.rb。
如何具体回滚该迁移文件?
当前回答
如果您想从上次迁移中恢复,请使用rake db:rollback命令。它对我很有效!
其他回答
嗯,在rails中这很简单
rake db:migrate:status
or
rails db:migrate:status
它被修改为以相同的方式处理两者。 然后选择要回滚的版本 然后运行
rake db:migrate VERSION=2013424230423
确保VERSION全部为大写字母。
如果您在迁移的任何步骤中遇到了问题,或者仅仅是卡在中间,请转到迁移文件并注释掉已经迁移的行。
rake db:migrate:down VERSION=20100905201547
将回滚特定的文件。
要找到所有迁移的版本,你可以使用这个命令:
rake db:migrate:status
或者,简单地说,迁移文件名的前缀就是需要回滚的版本。
请参阅Ruby on Rails指南中关于迁移的条目。
迁移使用该命令更改数据库的状态
bundle exec rake db:migrate
我们可以使用
bundle exec rake db:rollback
要从头再来,我们可以用
bundle exec rake db:migrate VERSION=0
正如您可能猜到的那样,将任何其他数字替换为0将迁移到该版本号,其中版本号来自按顺序列出的迁移。
rake db:rollback STEP=1
是一种方法,如果要回滚的迁移是最后应用的迁移。您可以将1替换为您想要返回的任意多次迁移。
例如:
rake db:rollback STEP=5
还将回滚之后发生的所有迁移(4,3,2和1)。
要将所有迁移回滚到(并包括)目标迁移,请使用:(此更正命令是在原始帖子中指出错误的所有注释之后添加的)
rake db:migrate VERSION=20100905201547
为了只回滚一个特定的迁移(乱序)使用:
rake db:migrate:down VERSION=20100905201547
注意,这不会回滚任何调解迁移——只回滚列出的迁移。如果这不是您想要的,您可以安全地运行rake db:migrate,它将只重新运行该文件,跳过之前未回滚的其他文件。
如果你想要迁移一个无序的迁移,还有它的逆db:migrate:up:
rake db:migrate:up VERSION=20100905201547
要回滚所有的迁移到一个特定的版本(例如20181002222222),使用:
rake db:migrate VERSION=20181002222222
(注意,这里使用的是db:migrate,而不是其他答案中的db:migrate:down。)
假设指定的迁移版本比当前版本更老,这将回滚到指定版本之前的所有迁移,但不包括指定版本。
例如,如果rake db:migrate:status初始显示:
(... some older migrations ...)
up 20181001002039 Some migration description
up 20181002222222 Some migration description
up 20181003171932 Some migration description
up 20181004211151 Some migration description
up 20181005151403 Some migration description
运行:
rake db:migrate VERSION=20181002222222
会导致:
(... some older migrations ...)
up 20181001002039 Some migration description
up 20181002222222 Some migration description
down 20181003171932 Some migration description
down 20181004211151 Some migration description
down 20181005151403 Some migration description
参考:只迁移或恢复某些迁移