导出数据库的所有数据成YML文件

本文介绍了一段Ruby代码,该代码用于从现有数据库中创建YAML测试数据集。默认使用开发环境数据库,可通过设置RAILS_ENV变量进行覆盖。代码支持导出所有表数据及特定引用表数据。
ruby 代码
  1. namespace :db do  
  2.   namespace :fixtures do  
  3.   
  4.     desc 'Create YAML test fixtures from data in an existing database.   
  5. Defaults to development database. Set RAILS_ENV to override.'   
  6.     task :dump_all => :environment do  
  7.       sql = "SELECT * FROM %s"  
  8.       skip_tables = ["schema_info"]   
  9.       ActiveRecord::Base.establish_connection(:development)   
  10.       (ActiveRecord::Base.connection.tables - skip_tables).each do |table_name|   
  11.         i = "000"  
  12.         File.open("#{RAILS_ROOT}/test/fixtures/#{table_name}.yml", 'w') do |file|   
  13.           data = ActiveRecord::Base.connection.select_all(sql % table_name)   
  14.           file.write data.inject({}) { |hash, record|   
  15.             hash["#{table_name}_#{i.succ!}"] = record   
  16.             hash   
  17.           }.to_yaml   
  18.         end  
  19.       end  
  20.     end  
  21.   end  
  22.      
  23.   namespace :fixtures do  
  24.     desc 'Create YAML test fixtures for references. Defaults to development database.    
  25.     Set RAILS_ENV to override.'   
  26.     task :dump_references => :environment do  
  27.       sql = "SELECT * FROM %s"  
  28.       dump_tables = ["areas","countries"]   
  29.       ActiveRecord::Base.establish_connection(:development)   
  30.       dump_tables.each do |table_name|   
  31.         i = "000"  
  32.         file_name = "#{RAILS_ROOT}/test/fixtures/#{table_name}.yml"  
  33.         p "Fixture save for table #{table_name} to #{file_name}"  
  34.         File.open(file_name, 'w') do |file|   
  35.           data = ActiveRecord::Base.connection.select_all(sql % table_name)   
  36.           file.write data.inject({}) { |hash, record|   
  37.             hash["#{table_name}_#{i.succ!}"] = record   
  38.             hash   
  39.           }.to_yaml   
  40.         end  
  41.       end  
  42.     end  
  43.   end  
  44. end   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值