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

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


当前回答

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

参考:只迁移或恢复某些迁移

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

您可以使用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是迁移的版本号。

嗯,在rails中这很简单

rake db:migrate:status

or

rails db:migrate:status

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

rake db:migrate VERSION=2013424230423

确保VERSION全部为大写字母。

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

此外:

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

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

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

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

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

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