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

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


当前回答

您可以使用rake db:rollback和不同的选项来回滚迁移。语法将根据您的需求有所不同。

如果您只想回滚最后一次迁移,那么可以使用这两种方法中的任何一种

rake db:rollback

or

rake db:rollback STEP=1

如果你想要一次回滚迁移数量,那么你只需传递一个参数:

rake db:rollback STEP=n

其中n是迁移到回滚的次数,从最近一次迁移开始计算。

如果你想要回滚到一个特定的迁移,那么你应该在下面传递迁移的版本:

rake db:migrate:down VERSION=xxxxx

其中XXXXX是迁移的版本号。

其他回答

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

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

rake db:migrate:down VERSION=20100905201547

将回滚特定的文件。


要找到所有迁移的版本,你可以使用这个命令:

rake db:migrate:status

或者,简单地说,迁移文件名的前缀就是需要回滚的版本。


请参阅Ruby on Rails指南中关于迁移的条目。

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

此外:

当您很久以前部署的迁移不允许您迁移新的迁移时。

我在一个较大的Ruby on Rails应用程序中工作,其中有超过1000个迁移文件。而且,我们需要一个月的时间来发布一个中等规模的功能。我正在开发一个功能,一个月前我已经部署了一个迁移,然后在审查过程中,迁移的结构和文件名发生了变化,现在我尝试部署我的新代码,构建失败了,说:

ActiveRecord::StatementInvalid: PG::DuplicateColumn: ERROR: column "my_new_field" of relation "accounts"已经存在

上述解决方案都不适合我,因为旧的迁移文件丢失了,而我打算在新迁移文件中创建的字段已经存在于数据库中。对我来说唯一有效的解决方法是:

我把文件转移到服务器上了 我打开了rails控制台 我在IRB会话中需要该文件 然后AddNewMyNewFieldToAccounts.new.down

然后我可以再次运行部署构建。

迁移使用该命令更改数据库的状态

bundle exec rake db:migrate

我们可以使用

bundle exec rake db:rollback

要从头再来,我们可以用

bundle exec rake db:migrate VERSION=0

正如您可能猜到的那样,将任何其他数字替换为0将迁移到该版本号,其中版本号来自按顺序列出的迁移。