提问人:AnApprentice 提问时间:9/6/2010 最后编辑:Timur ShtatlandAnApprentice 更新时间:9/6/2023 访问量:724597
如何回滚特定迁移?
How can I rollback a specific migration?
答:
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
评论
STEP=-1
rake db:migrate:status
rake db:migrate:down VERSION=20100905201547
将回滚特定文件。
若要查找所有迁移的版本,可以使用以下命令:
rake db:migrate:status
或者,迁移文件名的前缀就是您需要回滚的版本。
请参阅 Ruby on Rails 指南中关于迁移的条目。
评论
您可以使用不同的选项回滚迁移。语法将根据您的要求而有所不同。rake db:rollback
如果只想回滚上次迁移,则可以使用
rake db:rollback
或
rake db:rollback STEP=1
如果你想一次回滚迁移次数,那么你只需传递一个参数:
rake db:rollback STEP=n
其中 是要回滚的迁移数,从最新迁移开始计算。n
如果要回滚到特定迁移,则应在以下各项中传递迁移版本:
rake db:migrate:down VERSION=xxxxx
其中 xxxxx 是迁移的版本号。
评论
用:
rake db:migrate:down VERSION=your_migrations's_version_number_here
版本是迁移文件名上的数字前缀。
如何查找版本:
迁移文件存储在目录中。找到要回滚到的相应文件并复制前缀编号。rails_root/db/migrate
例如:
文件名:20140208031131_create_roles.rb
则版本为 .20140208031131
评论
rake db:migrate:status
如果是可逆迁移,并且是已执行的最后一个迁移,则运行 。而且您可以随时使用该版本。rake db:rollback
例如,如果迁移文件是 20140716084539_create_customer_stats.rb,则回滚命令将为:
rake db:migrate:down VERSION=20140716084539
若要回滚上次迁移,可以执行以下操作:
rake db:rollback
如果要使用某个版本回滚特定迁移,则应执行以下操作:
rake db:migrate:down VERSION=YOUR_MIGRATION_VERSION
例如,如果版本是20141201122027,您将执行
rake db:migrate:down VERSION=20141201122027
以回滚该特定迁移。
若要回滚上次迁移,可以执行以下操作:
rake db:rollback
如果要使用某个版本回滚特定迁移,应执行以下操作:
rake db:migrate:down VERSION=YOUR_MIGRATION_VERSION
如果要回滚的迁移文件已调用,则该迁移的 VERSION 为 ,这是创建该迁移时的时间戳,回滚该迁移的命令为:db/migrate/20141201122027_create_some_table.rb
20141201122027
rake db:migrate:down VERSION=20141201122027
如果要回滚和迁移,可以运行:
rake db:migrate:redo
这与以下相同:
rake db:rollback
rake db:migrate
迁移使用以下命令更改数据库的状态
bundle exec rake db:migrate
我们可以使用
bundle exec rake db:rollback
要一直回到开头,我们可以使用
bundle exec rake db:migrate VERSION=0
正如您可能猜到的那样,将任何其他数字替换为 0 将迁移到该版本号,其中版本号来自按顺序列出迁移。
评论
嗯,在 rails 5 中,这很容易
rake db:migrate:status
或
rails db:migrate:status
它被修改为以相同的方式处理两者。 然后只需选择要回滚的版本 然后运行
rake db:migrate VERSION=2013424230423
确保 VERSION 全部为大写字母。
如果您在迁移的任何步骤中遇到问题或只是卡在中间,请转到迁移文件并注释掉已迁移的行。
评论
回滚上次迁移:
# rails < 5.0
rake db:rollback
# rails >= 5.0
rake db:rollback
# or
rails db:rollback
回滚上次迁移次数n
# rails < 5.0
rake db:rollback STEP=2
# rails >= 5.0
rake db:rollback STEP=2
# or
rails db:rollback STEP=2
回滚特定迁移
# rails < 5.0
rake db:migrate:down VERSION=20100905201547
# rails >= 5.0
rake db:migrate:down VERSION=20100905201547
# or
rails db:migrate:down 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
参考:仅迁移或还原部分迁移
此外:
如果很久以前部署的迁移不允许迁移新的迁移。
我在一个更大的 Ruby on Rails 应用程序中工作,该应用程序包含一千多个迁移文件。而且,我们需要一个月的时间才能发布一个中型功能。我正在开发一个功能,一个月前我部署了一个迁移,然后在审查过程中迁移的结构和文件名发生了变化,现在我尝试部署我的新代码,构建失败说:
ActiveRecord::StatementInvalid:PG::D uplicateColumn:错误:关系“accounts”的列“my_new_field”已存在
上述解决方案都不适合我,因为旧的迁移文件丢失了,并且我打算在新迁移文件中创建的字段已存在于数据库中。唯一对我有用的解决方案是:
- 我将文件编辑到服务器
scp
- 我打开了
rails console
- 我在 IRB 会话中需要该文件
- 然后
AddNewMyNewFieldToAccounts.new.down
然后我可以再次运行部署版本。
对于多数据库配置 (RoR >= v6),必须在命令中附加数据库名称,例如:
rails db:rollback:primary
,其中 primary 是文件中数据库的名称,用于回滚上次迁移。您可以像往常一样在此处使用 STEPS 属性。config/databases.yml
rails db:migrate:down:primary VERSION=your_migration_timestamp
,以仅还原提供的迁移版本。这里 primary 也是数据库的名称。
我发现这些步骤最有用。
要检查状态,请运行 。然后,你就可以很好地了解要删除的迁移。rails db:migrate:status
然后,运行以逐个还原更改。执行此操作后,您可以再次检查状态以完全自信。rails db:rollback
接下来,如果要删除或删除。跑。这将清理您创建的版本。rails d migration <migration_name>
完成后,您可以继续进行新的更改。
如果您使用的是 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
评论
如果要从上次迁移中恢复,请使用 rake db:rollback 命令。它对我来说工作正常!
评论
迁移文件如下所示,
20221213051020_my_migrations
在这种情况下,模型名称应为 。迁移以复数单词结尾,因此以 .MyMigration
migrations
若要回滚此特定迁移,必须了解迁移名称的第一部分(迁移名称前面的数字)是迁移编号。
要回滚此迁移,只需打开终端并编写:
rake db:migrate:down VERSION=migration_number
所以最后,你必须实际输入终端来回滚这个特定的迁移,
在终端上写下以下命令来回滚特定的迁移,上面的命令只是为了解释你
rake db:migrate:down VERSION=20221213051020
请记住,每次迁移都有不同的迁移编号,因此请仔细观察并手动复制粘贴或键入。
您可以运行迁移命令来回滚迁移,如下所示:down
rake db:migrate:down VERSION=20100905201547
如果使用 VSCode,则可以创建以下任务
{
"label": "rollback open migration",
"type": "shell",
"command": "rails db:migrate:down VERSION=$(basename ${file} .rb | cut -d '_' -f 1)"
},
运行该任务将回滚在文件编辑器中打开的迁移
评论
Class.down