Mysql
 sql >> Base de données >  >> RDS >> Mysql

Migrer certains objets d'une base de données à une autre

D'accord.

God Save the YAML

J'ai utilisé le vidage YAML dans un fichier à partir du développement et je l'ai chargé dans ma production. Il y a eu un piratage avec l'identifiant, qui a changé, car c'est auto_increament.

développement

user     = User.find X
posts    = user.posts
comments = user.comments
...
File.open("user.yml", "w")    { |f| f << YAML::dump(user) }
File.open("comments.yml", "w"){ |f| f << YAML::dump(comments) }
File.open("posts.yml", "w")   { |f| f << YAML::dump(posts) }
...

production

user     = YAML::load_file("user.yml")
posts    = YAML::load_file("posts.yml")
comments = YAML::load_file("comments.yml")
new_user = user.clone.save # we should clone our object, because it isn't exist
posts.each do |p|
  post = p.clone
  post.user = new_user
  post.save
end
...