我有rails应用程序连接到多个数据库.我写了如下定制的耙子任务:
@H_403_2@task :migrate_accounts_schema => [:environment] do |t|
users = User.find :all,:conditions => ["state = 2"],:order => "id asc"
users.each do |user|
if user.state == 2
ActiveRecord::Base.establish_connection(
:adapter => "postgresql",:host => user.database_host,:port => user.database_port,:username => user.subdomain,:password => "#{user.database_password}",:database => user.database_name
)
Rake::Task["db:migrate"].invoke
end
end
end
问题是任务执行db:仅迁移用户[0]用户(集合中的第一个用户),并且没有错误,只是静静地停止…
这是rake –trace的输出
@H_403_2@** Invoke app:migrate_accounts_schema (first_time) ** Invoke environment (first_time) ** Execute environment ** Execute app:migrate_accounts_schema ** Invoke db:migrate (first_time) ** Invoke environment ** Execute db:migrate ** Invoke db:schema:dump (first_time) ** Invoke environment ** Execute db:schema:dump ** Invoke db:migrate我不知道为什么其他用户不能迁移.