Rake db:seed 您必须传递哈希作为参数 - 尝试插入 json



我有一个 json 文件,我想把它放到数据库中,这里是,http://pastebin.com/m3GsTfdi

这是我要在其中存储此信息的表的迁移文件;

create_table :characters do |t|
  t.string :name
  t.string :region
  t.string :realm
  t.integer :class
  t.integer :race
  t.integer :level
  t.integer :achievementPoints
  t.string :items
  t.string :stats
  t.string :hunterPets
  t.string :talents
  t.string :progresison
  t.timestamps null: false
end

这就是我尝试通过 seed.rb 插入字符的方式

JSON.parse(open("#{Rails.root}/app/assets/seed/netfive.json").read).each do |chardata|
  Character.create(chardata)
end

但是我收到错误"参数错误:分配属性时,必须将哈希作为参数传递。当我运行耙子 db:seed 时。

我应该如何解决它?我认为这与我正在尝试保存一个应该是字符串的数组有关,但我不确定该怎么做。

编辑:我设法像这样修复它;

char_data = JSON.parse(File.read("#{Rails.root}/app/assets/seed/netfive.json"))
Character.new({
                     name:char_data['name'],
                     realm:char_data['realm'],
                     charClass:char_data['class'],
                     race:char_data['race'],
                     level:char_data['level'],
                     achievementPoints:char_data['achievementPoints'],
                     items:char_data['items'],
                     stats:char_data['stats'],
                     hunterPets:char_data['hunterPets'],
                     talents:char_data['talents'],
                     progression:char_data['progression'],
                 }).save

我还使用了以前在注释中链接的序列化。

感谢您的帮助!

当您遍历 JSON 时,您将遍历 JSON 中的每个键和值。这不是你想要的。您希望从数据创建一个字符。

它看起来像这样:

char_data = JSON.parse(File.read("#{Rails.root}/app/assets/seed/netfive.json"))
Character.create char_data

执行此操作时,您必须小心数据类型。 即,您可能在将items保存为字符串时遇到问题。相反,我会考虑序列化该数据。

下面是序列化的参考:http://apidock.com/rails/ActiveRecord/AttributeMethods/Serialization/ClassMethods/serialize

最新更新