我有一个迁移文件db\migrate\20100905201547_create_blocks.rb。
如何具体回滚该迁移文件?
我有一个迁移文件db\migrate\20100905201547_create_blocks.rb。
如何具体回滚该迁移文件?
当前回答
要回滚上次迁移,您可以执行以下操作:
rake db:rollback
如果你想用一个版本回滚一个特定的迁移,你应该做:
rake db:migrate:down VERSION=YOUR_MIGRATION_VERSION
例如,如果版本号是20141201122027,您将这样做
rake db:migrate:down VERSION=20141201122027
回滚特定的迁移。
其他回答
我发现这些步骤最有用。
执行rails db:migrate:status命令查看状态。然后,您将对想要删除的迁移有一个很好的了解。
然后执行rails db:rollback命令将修改的内容逐一恢复。这样做之后,您可以再次检查状态,以充分自信。
下一步,如果您想删除或删除。执行rails d migration <migration_name>。这将清理您创建的版本。
完成这些之后,您可以继续进行新的更改。
要回滚上次迁移,您可以执行以下操作:
rake db:rollback
如果你想用一个版本回滚一个特定的迁移,你应该做:
rake db:migrate:down VERSION=YOUR_MIGRATION_VERSION
例如,如果版本号是20141201122027,您将这样做
rake db:migrate:down VERSION=20141201122027
回滚特定的迁移。
嗯,在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
然后我可以再次运行部署构建。
如果你使用的是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