在数据库中存储数组:JSON与序列化数组

时间:2014-01-23 15:19:40

标签: ruby-on-rails arrays json

我想存储一个包含3个元素的数组:帖子的最后3条评论。我知道我可以将评论表加入Post一个,但我会避免为扩展目的做这个繁重的请求。

所以我想知道存储这3个元素的最佳方法是什么,因为我希望每次发表新评论时都能轻松更新它们:删除最后一条评论并添加新评论。

这样做的正确方法是什么?将它存储在序列化数组或JSON对象中?

1 个答案:

答案 0 :(得分:72)

您可以使用ActiveRecord的serialize声明来存储数组和哈希:

class Comment < ActiveRecord::Base
  serialize :stuff
end

comment = Comment.new  # stuff: nil
comment.stuff = ['some', 'stuff', 'as array']
comment.save
comment.stuff # => ['some', 'stuff', 'as array']

您可以指定对象类型应该等于的类名(在本例中为Array)。这更明确,更安全一点。分配第一个值时,您也不必创建数组,因为您将能够附加到现有(空)数组。

class Comment < ActiveRecord::Base
  serialize :stuff, Array
end

comment = Comment.new  # stuff: []
comment.stuff << 'some' << 'stuff' << 'as array'

您甚至可以使用名为store的整洁版本:http://api.rubyonrails.org/classes/ActiveRecord/Store.html

这应该使用内置方法处理您的用例。