我有一个 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