我有一个迁移文件db\migrate\20100905201547_create_blocks.rb。
如何具体回滚该迁移文件?
我有一个迁移文件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是迁移的版本号。
其他回答
迁移文件是这样的,
20221213051020_my_migrations
在本例中,模型名应该是MyMigration。migration以一个复数词结尾,所以它以migrations结尾。
要回滚这个特定的迁移,您必须理解迁移名称的第一部分(迁移名称前面的数字)是迁移编号。
要回滚这次迁移,只需打开终端并写入,
rake db:migrate:down VERSION=migration_number
最后,你必须在终端中输入回滚这个特定的迁移,
在终端上写下面的命令回滚一个特定的迁移,上面的命令只是给你解释
rake db:migrate:down VERSION=20221213051020
只需记住,每次迁移都有不同的迁移编号,因此请仔细观察并手动复制、粘贴或键入。
如果您想从上次迁移中恢复,请使用rake db:rollback命令。它对我很有效!
迁移使用该命令更改数据库的状态
bundle exec rake db:migrate
我们可以使用
bundle exec rake db:rollback
要从头再来,我们可以用
bundle exec rake db:migrate VERSION=0
正如您可能猜到的那样,将任何其他数字替换为0将迁移到该版本号,其中版本号来自按顺序列出的迁移。
您可以使用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是迁移的版本号。
rake db:migrate:down VERSION=20100905201547
将回滚特定的文件。
要找到所有迁移的版本,你可以使用这个命令:
rake db:migrate:status
或者,简单地说,迁移文件名的前缀就是需要回滚的版本。
请参阅Ruby on Rails指南中关于迁移的条目。