summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2014-01-12 09:02:31 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2014-01-12 09:02:31 +0000
commitb25c7003da4b0baef84e0b6a68e411bfec7d6177 (patch)
tree5974a77e6b000e25d20f87c685e1d54e428d5b40
parentb9f45c80c655f56998b869d86d8962ef4bb0784a (diff)
downloadredmine-b25c7003da4b0baef84e0b6a68e411bfec7d6177.tar.gz
redmine-b25c7003da4b0baef84e0b6a68e411bfec7d6177.zip
Adds a task for moving Redmine data to a different DBMS.
git-svn-id: http://svn.redmine.org/redmine/trunk@12659 e93f8b46-1217-0410-a6f0-8f06a7374b81
-rw-r--r--lib/tasks/redmine.rake43
1 files changed, 43 insertions, 0 deletions
diff --git a/lib/tasks/redmine.rake b/lib/tasks/redmine.rake
index 0ad4f2f1a..dd15362a1 100644
--- a/lib/tasks/redmine.rake
+++ b/lib/tasks/redmine.rake
@@ -53,6 +53,49 @@ namespace :redmine do
Rake::Task["redmine:plugins:assets"].invoke
end
+desc <<-DESC
+FOR EXPERIMENTAL USE ONLY, Moves Redmine data from production database to the development database.
+This task should only be used when you need to move data from one DBMS to a different one (eg. MySQL to PostgreSQL).
+WARNING: All data in the development database is deleted.
+DESC
+
+ task :migrate_dbms => :environment do
+ ActiveRecord::Base.establish_connection :production
+
+ (ActiveRecord::Base.connection.tables - %w(schema_migrations plugin_schema_info)).each do |table_name|
+ Source = Class.new(ActiveRecord::Base)
+ Target = Class.new(ActiveRecord::Base)
+ Target.establish_connection(:development)
+
+ [Source, Target].each do |klass|
+ klass.table_name = table_name
+ klass.reset_column_information
+ klass.inheritance_column = "foo"
+ klass.record_timestamps = false
+ end
+ Target.primary_key = (Target.column_names.include?("id") ? "id" : nil)
+
+ source_count = Source.count
+ puts "Migrating %6d records from #{table_name}..." % source_count
+
+ Target.delete_all
+ offset = 0
+ while (objects = Source.offset(offset).limit(5000).order("1,2").to_a) && objects.any?
+ offset += objects.size
+ Target.transaction do
+ objects.each do |object|
+ new_object = Target.new(object.attributes)
+ new_object.id = object.id if Target.primary_key
+ new_object.save(:validate => false)
+ end
+ end
+ end
+ Target.connection.reset_pk_sequence!(table_name) if Target.primary_key
+ target_count = Target.count
+ abort "Some records were not migrated" unless source_count == target_count
+ end
+ end
+
namespace :plugins do
desc 'Migrates installed plugins.'
task :migrate => :environment do