我有一个迁移文件db\migrate\20100905201547_create_blocks.rb。

如何具体回滚该迁移文件?


当前回答

如果您想从上次迁移中恢复,请使用rake db:rollback命令。它对我很有效!

其他回答

如果你想要回滚和迁移,你可以运行:

rake db:migrate:redo

也就是:

rake db:rollback
rake db:migrate

对于多个数据库配置(RoR >= v6),您必须在命令中附加数据库名称,例如:

Rails db:rollback:primary,其中primary是config/databases中数据库的名称。Yml文件,回滚上次迁移。与往常一样,您可以在这里使用STEPS属性。 rails db:migrate:down:primary VERSION=your_migration_timestamp,只恢复提供的迁移版本。这里primary也是数据库的名称。

嗯,在rails中这很简单

rake db:migrate:status

or

rails db:migrate:status

它被修改为以相同的方式处理两者。 然后选择要回滚的版本 然后运行

rake db:migrate VERSION=2013424230423

确保VERSION全部为大写字母。

如果您在迁移的任何步骤中遇到了问题,或者仅仅是卡在中间,请转到迁移文件并注释掉已经迁移的行。

如果你使用的是Ruby on Rails 3

步骤:1(检查最后一次迁移)

bundle exec rake db:migrate:status

步骤:2(回滚上一次迁移)

bundle exec rake db:rollback

现在,您可以逐个安全地恢复迁移。

对于特定的迁移

Rails d migration <migration_name>

用于恢复多次迁移

bundle exec rake db:rollback STEP=n

其中n是要回滚的迁移次数。

例如:bundle exec rake db:rollback STEP=5

迁移文件是这样的,

 20221213051020_my_migrations

在本例中,模型名应该是MyMigration。migration以一个复数词结尾,所以它以migrations结尾。

要回滚这个特定的迁移,您必须理解迁移名称的第一部分(迁移名称前面的数字)是迁移编号。

要回滚这次迁移,只需打开终端并写入,

rake db:migrate:down VERSION=migration_number

最后,你必须在终端中输入回滚这个特定的迁移,

在终端上写下面的命令回滚一个特定的迁移,上面的命令只是给你解释

rake db:migrate:down VERSION=20221213051020

只需记住,每次迁移都有不同的迁移编号,因此请仔细观察并手动复制、粘贴或键入。