从数据库中已有的数据创建种子文件

swr*_*bel 50 rake activerecord ruby-on-rails ruby-on-rails-3

我正在使用Rails 3.0.3并且已经在数据库中拥有我的"类别"表的数据,但是想要从中创建种子文件.是否有任何rake任务将从此表中为我生成seeds.rb格式?

小智 64

有一个名为gem的宝石seed_dump,它可以完全按照您的要求进行操作:

  • 我找到了新的Github家,万一有人正在寻找它 - https://github.com/zenprogrammer/seed_dump (10认同)
  • 这不适用于协会我们还可以包含记录的ID吗? (4认同)

Bri*_*ian 29

不确定任何现有的rake任务,但你可以尝试在rails控制台中运行这样的东西并将结果粘贴到seeds.rb文件中

(警告:脏和未经测试)

c = Category.all

c.each do |cat|
  puts "Category.create(:name => '#{cat.name}')"
end
Run Code Online (Sandbox Code Playgroud)

调整您可能拥有的任何其他字段.

希望这可以帮助.


Mat*_*lay 7

我已经使用YamlDb从我的开发数据库转储数据,然后将其加载到另一台服务器.它将数据转储到Yaml文件,该文件将在您希望使用db:load将其推送到任何其他数据库服务器时使用.

https://github.com/ludicast/yaml_db


Rub*_*cer 5

旧问题,我有一个基于@Brian答案的新问题。

如果要保留整行:

seedfile = File.open('db/seeds.rb', 'a')

c = Category.all

c.each do |cat|
  seedfile.write "Category.create(#{cat.attributes})\n"
end

seedfile.close
Run Code Online (Sandbox Code Playgroud)

如果只想写一些属性,请将写行更改为以下内容:

seedfile.write "Category.create(#{cat.attributes.slice('attr1', 'attr2', ...})\n"
Run Code Online (Sandbox Code Playgroud)

或者,如果您希望除某些属性外的所有属性,例如时间戳记:

seedfile.write "Category.create(#{cat.attributes.except('created_at', 'updated_at')})\n"
Run Code Online (Sandbox Code Playgroud)