`

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

阅读更多
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   
分享到:
评论

相关推荐

    java解析Excel文件并把数据存入数据库和导出数据为excel文件SpringBoot代码示例

    2、java读取数据库数据,并导出为excel文件。 3、README.md中有详细的操作步骤示例。 使用说明: 1. 先使用postman导入:other/excel相关.postman_collection.json 2. 导入sql到数据库:other/excel.sql 3. idea导入...

    springboot实现将数据库中数据导出Excel

    在Spring Boot框架中,开发人员可以利用其便捷的特性来高效地处理各种任务,包括从数据库中导出数据到Excel文件。本项目基于Spring Boot和MyBatis,这两个流行的Java库,提供了简单且易于理解的方式来实现这个功能。...

    连接数据库,根据数据库表格式导出excel数据字段内容及注释

    在IT行业中,数据库管理和数据导出是至关重要的任务,尤其在项目需求分析、设计和开发阶段。本项目名为"连接数据库,根据数据库表格式导出excel数据字段内容及注释",它提供了一种便捷的方式来获取数据库表的信息,...

    若依(ruoyi)导出的nacos配置文件

    导出的配置文件,如 `.metadata.yml` 和 `DEFAULT_GROUP`,包含了 Ruoyi 在运行时所需的关键配置信息,可能涉及到数据库连接、服务地址、权限设置等。 【知识点详细说明】: 1. **Nacos**:Nacos 是一个为云应用...

    Redmine备份数据库文件

    执行后,系统会生成一个名为`backup.sql`的SQL文件,包含了数据库的所有结构和数据。 #### 1.2 使用图形化工具 如果你更喜欢使用图形界面,可以使用如Navicat for MySQL这样的工具。打开Navicat,连接到MySQL...

    SpringBoot使用EasyPoi将Mysql数据库中的数据导入到Excel文件中并把Excel文件中的数据导入到Mysql数据库中

    在本文中,我们将探讨如何使用SpringBoot集成EasyPoi库,实现从MySQL数据库中导出数据到Excel文件,以及从Excel文件中导入数据到MySQL数据库的功能。首先,我们需要理解EasyPoi是一个Java处理Excel的开源工具,它...

    《开发工具篇--screw数据库文档生成工具》

    在SpringBoot的配置文件application.yml或application.properties中,你需要指定数据库连接信息以及生成文档的相关设置,如输出格式(HTML、Markdown等)、输出路径等。例如: ```yaml screw: driver-class-name: ...

    在IntelliJ IDEA中通过Spring Boot集成达梦数据库:从入门到精通

    达梦数据库是一款由中国自主研发的高性能、高安全性的关系型数据库管理系统,它在大数据处理和安全性方面具有出色的表现。下面我们将详细讲解集成过程中的关键知识点。 1. **环境准备** 在开始之前,确保你已安装...

    Springboot + Hutool-db 使用 URLClassLoader 动态加载外部数据库和数据池 jar包实例

    在Spring Boot项目中,我们通常会将数据库连接信息写入`application.properties`或`application.yml`配置文件中。然而,为了实现动态加载,我们可以使用URLClassLoader,这是一个Java类加载器,它可以加载指定URL...

    基于SpringBoot的开源数据库表结构导出word文档工具.zip

    【标题】"基于SpringBoot的开源数据库表结构导出word文档工具"是一个实用的Java开发项目,它利用SpringBoot框架来实现数据库表结构的自动化导出功能,将数据以Word文档的形式呈现,非常适合用于毕业设计或课程设计。...

    nacos中配置文件压缩包

    2. **获取数据**:可以导出Nacos当前数据库的SQL脚本或者直接导出数据库备份文件。 3. **修改配置**:在新的环境中,可能需要更新`db.properties`文件中的数据库连接信息,使其指向新环境的数据库。 4. **导入数据...

    oracle与greenplum数据交互.docx

    - **COPY命令**:适用于较小规模的数据导出,通过Master节点收集所有节点的数据进行串行导出。 - **语法**: ```sql COPY (SELECT * FROM tab_name) TO 'path/filename' CSV; ``` #### 5. Greenplum数据导入 - ...

    关于在compose数据窗口中进行数据转移

    在Compose文件(docker-compose.yml)中,可以定义数据卷,并将其挂载到特定的容器路径,确保即使容器被销毁,数据依然保存。例如: ```yaml version: '3' services: db: image: postgres volumes: - data:/...

    Task5:导入导出文件

    在这个上下文中,它可能指示开发者需要提供一个包含数据库配置信息的YML文件。 2. **数据库配置.yml**:这是一个YML文件,通常用于存储数据库连接信息,如数据库名、用户名、密码和主机地址。在Ruby on Rails应用中...

    调试完毕导出的jeesite源码

    5. **数据库设置**: 在运行jeesite前,你需要在你的本地或者服务器上创建一个数据库,并根据项目中的配置文件(通常为application.properties或application.yml)更改数据库连接信息,包括数据库URL、用户名、密码等...

    springbootpoi-demo.zip

    6. **导入导出操作**: 这里是指从Excel文件中读取数据并将其存储到数据库,或者从数据库中检索数据并写入Excel文件的过程。这种操作在数据分析、报表生成、数据交换等方面非常常见。 7. **SpringBoot配置**: 为了...

    基于ssm的微信小程序二手图书交易系统源码数据库.zip

    - **数据库文件**:可能是SQL脚本或数据库导出文件,用于初始化和管理交易系统的数据库结构和数据。 - **配置文件**:如application.properties或application.yml,用于设置Spring Boot应用的配置,包括数据库连接...

Global site tag (gtag.js) - Google Analytics