将json文件数据保存到Rails数据库中

如何解决将json文件数据保存到Rails数据库中

我有一个使用rails 5.2.1的Rails API,并且正在开发一个Web Scraping API,该API使用Mechanize Gem提取Web数据。

要做的是,将所有这些Web抓取数据数据传递给React.js,但是首先我需要在数据库获取这些数据,我很难确定这个。

因此,当我提取数据并将其全部接收到一个JSON文件(称为data.json)时,我惊讶地发现,直到这里哈哈。

{
  "Brazil":[
  {"Jungle Plants":[bla bla bla ]},{"Desert Plants":[ bla bla bla ]}],"Egypt":[
  {"Jungle Plants":[bla bla bla ]},{"Desert Plants":[ bla bla bla ]}]
  
  and so on...
}

因此,我下一步要做的是将JSON数据分离到数据库中,该数据库已经具有如下迁移设置:

class CreatePlants < ActiveRecord::Migration[5.2]
  def change
    create_table :plants do |t|
      t.string :country_name
      t.string :plant_categories

      t.timestamps
    end
  end
end

所以在表中我想要的是,我希望将“巴西”或“埃及”之类的国家名称或其他任何国家名称放入 country_name 列,对于 plant_categories 。

我的问题是,如何将data.json文件组织/分离到数据库中?非常感谢您的帮助!

解决方法

这是我的方法,我将使用JSON或JSONB列来保存每个数组来自主体的数组,因此我将迁移更改为:

class CreatePlants < ActiveRecord::Migration[5.2]
  def change
    create_table :plants do |t|
      t.string :country_name
      t.jsonb :data

      t.timestamps
    end
  end
end

因此,假设您具有已解析的响应(在主体上应用JSON.parse之后),则产生以下哈希值:

response =
  {
    "Brazil": [
      { "Jungle Plants": [ bla bla bla ] },{ "Desert Plants": [ bla bla bla ] }
    ],"Egypt": [
      { "Jungle Plants": [ bla bla bla ] },{ "Desert Plants": [ bla bla bla ] }
    ]

    and so on...
  }

我愿意:

response.each { |key,value| Plant.create!(country_name: key,data: value) }

那样,如果您在上一条语句之后执行以下命令:

Plant.find_by(country_name: 'Brazil').data

您将获得阵列:

[{ "Jungle Plants": [ bla bla bla ] },{ "Desert Plants": [ bla bla bla ] }]

但这是您的决定,可以用不同的方式完美解决此“问题”,例如,可以将数组另存为string,然后从数据库中检索它们并应用{{1} }或在模型定义中应用serialize method,以将它们再次转换为JSON.parse。另一个选择是进一步过滤响应并将其保存在更多列中。

我会说,最好的方法取决于您以后要处理的数据,但是出于灵活性的考虑,我选择的是我之前说过的方法,以将数组从API中保存到JSONB列中然后对它们执行我想要的任何操作(另一个优点是,将数据另存为JSONB允许您以无法仅使用字符串的方式对它们执行查询)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?