是否有一种简单的方法来运行单个迁移?我不想迁移到某个版本,我只想运行一个特定的版本。


当前回答

如果你在路径上有问题,你可以使用

require Rails.root + 'db/migrate/20090408054532_add_foos.rb'

其他回答

你可以直接从ruby文件中运行代码:

rails console
>> require "db/migrate/20090408054532_add_foos.rb"
>> AddFoos.new.up

注意:非常老版本的rails可能需要addfoo。up而不是addfoo .new.up。

另一种方法(没有IRB)依赖于require返回类名数组的事实:

script/runner 'require("db/migrate/20090408054532_add_foos.rb").first.constantize.up'

注意,如果这样做,就不会更新schema_migrations表,但这似乎正是您想要的结果。

此外,如果无法找到文件,您可能需要使用require("./db/…"或根据您的工作目录尝试require_relative

看起来至少在最新的Rails发行版(撰写本文时为5.2)中还有一种过滤正在运行的迁移的方法。可以在SCOPE环境变量中传递一个过滤器,然后使用该过滤器选择迁移文件。

假设您有两个迁移文件1_add_foos。Rb和2_add_fos .run_this_one. Rb运行

SCOPE=run_this_one rails db:migrate:up

将只选择并运行2_add_fos .run_this_one.rb。请记住,将运行与范围匹配的所有迁移文件。

至于rails 5,你也可以使用rails来代替rake

Rails 3 - 4

# < rails-5.0
rake db:migrate:up VERSION=20160920130051

Rails 5

# >= rails-5.0
rake db:migrate:up VERSION=20160920130051

# or

rails db:migrate:up VERSION=20160920130051

如果你在路径上有问题,你可以使用

require Rails.root + 'db/migrate/20090408054532_add_foos.rb'

方法一:

rake db:migrate:up VERSION=20080906120000

方法2:

在Rails控制台中 1. 在控制台复制粘贴迁移类(例如add_name_to_user.rb) 2. 然后在控制台输入以下命令

Sharding.run_on_all_shards{AddNameToUser.up}

结束了!!