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


当前回答

如果您希望运行特定的迁移,请执行

$ rake db:migrate:up VERSION=20080906120000

如果您想多次运行迁移,那么就这样做

# use the STEP parameter if you need to go more than one version back
$ rake db:migrate:redo STEP=3

如果您希望多次运行一个迁移,那么就这样做

# this is super useful
$ rake db:migrate:redo VERSION=20080906120000

(您可以在迁移的文件名中找到版本号)


编辑:您也可以简单地重命名您的迁移文件,例如:

20151013131830 _my_migration。Rb -> 20151013131831_my_migration.rb

然后正常迁移,这将把迁移视为一个新的迁移(如果您想在您控制较少的远程环境(如登台)上迁移,则非常有用)。

编辑2:您还可以在数据库中删除迁移条目。例如:

rails_c> q = "delete from schema_migrations where version = '20151013131830'"
rails_c> ActiveRecord::Base.connection.execute(q)

Rake db:migrate会重新运行nuked迁移的up方法。

其他回答

假设你可以运行最新版本的Rails:

rake db:migrate:up VERSION=20090408054532

其中version是迁移文件名中的时间戳。

编辑:在过去8年的某个时候(我不确定是哪个版本),Rails添加了检查,如果它已经运行,则阻止它运行。schema_migrations表中的一个条目表明了这一点。要重新运行它,只需执行rake db:migrate:redo VERSION=20090408054532即可。

你可以直接从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

如果你已经实现了这样一个change方法:

class AddPartNumberToProducts < ActiveRecord::Migration
  def change
    add_column :products, :part_number, :string
  end
end

你可以创建一个迁移实例,并在实例上运行migrate(:up)或migrate(:down),如下所示:

$ rails console
>> require "db/migrate/20090408054532_add_part_number_to_products.rb"
>> AddPartNumberToProducts.new.migrate(:down)

方法一:

rake db:migrate:up VERSION=20080906120000

方法2:

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

Sharding.run_on_all_shards{AddNameToUser.up}

结束了!!

请注意,您可能不得不在新的rails环境中使用rails runner而不是script/runner。