导出数据库的所有数据成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   
博客地址:http://blog.youkuaiyun.com/vipbooks 一直以来根据数据库表结构自动生JavaBean、自动生MyBaits的Mapper映射配置文件、自动生数据库设计文档都是一件让人很头痛的事情,既浪费时间又很繁琐,看着几十上百个表的千上万个字段,真是一件让人痛苦的事情。 我们也想过很多办法解决这个问题,包括用MyEclipse连接数据库JavaBean,但多多少少还是会有一些不尽人意的地方,包括表和表字段的comment总是无法生,而且还会生很多无用的注释代码,让代码看起来一点都不干净,配置非常繁琐等等问题。 于是一怒之下,自己动手丰衣足食,于是就自己用Swing写了一个基于数据库的自动化生工具,支持MySQL、Oracle、SQLServce、PostgreSQL四种数据库,支持Window、Linux、MacBook等多个作系统,完美支持JPA注解,可以同时生Entity和DTO等,可以自动去除表前缀,支持单个和批量生JavaBean,现在不但员变量上能生备注了,而且在Getter和Setter上也能有注释了。更重要的是还能自动生数据库设计文档和MyBaits的Mapper映射配置文件,如果有多个数据源还能批量生,使用非常方便。 所有的配置都保存在本地,只要配置过一次,下次使用的时候完全可以秒生JavaBean、MyBaits的Mapper映射配置文件数据库设计文档,并且还集各种实用工具,使得工作效率瞬间爆棚,生产力瞬间爆表! TableGo v5.8.0版更新震撼发布,此次版本更新如下: 1、新增自定义文件功能,可以自己编写模板生任意代码的文件。 2、新增数据源配置自动生功能,项目分库分表不用愁,一次搞定所有数据源。 3、公共参数界面新增表别名和是否目录直通的配置。 4、生Bean界面新增是否生字段注释和重写equals,hashCode,toString方法的配置。 5、MyBatis配置界面新增根据所有字段条件查询数据的选项。 6、新增TableGo使用说明书。 7、更新数据库驱动版本,新版的驱动可能不支持JDK8以下的版本。 8、修复了大量的Bug并进行了一些优化。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值