我如何序列化 - 反序列化哈希以便将其保存在数据库中?

时间:2012-07-30 21:34:48

标签: ruby-on-rails ruby serialization hash

我有一个哈希:

h = {
    "revision"=>7,         
    "rev"=>"708a4bd5b", 
    "thumb_exists"=>false, 
    "bytes"=>246000,     
    "modified"=>"Sun, 01 Jul 2012 17:09:15 +0000", 
    "client_mtime"=>"Sun, 01 Jul 2012 17:09:15     +0000", 
    "path"=>"/Getting Started.pdf", 
    "is_dir"=>false,       
    "icon"=>"page_white_acrobat", 
    "root"=>"dropbox",     
    "mime_type"=>"application/pdf", 
    "size"=>"240.2 KB"
}

我想使用以下命令将其保存在数据库中:h.to_s 然后我想从数据库中获取内容并将其作为哈希值使用。

s = MyModel[:field_which_contains_hash_string]

我尝试使用YAML::load s加载内容,但收到错误:

Psych::SyntaxError: (<unknown>): found unexpected ':' while scanning a plain scalar at line 1 column 96

我想这是由于时间字符串中的冒号所致。 那么,保持哈希并再次检索它的最佳方法是什么?

帮助表示赞赏。 最好, 菲利普

1 个答案:

答案 0 :(得分:13)

在模型中创建一个text类型的列。然后在您的模型文件中执行

class MyModel < ActiveRecord::Base
    serialize :column_name, Hash
end

然后使用以下方式访问它:

my_model = MyModel.new
my_model.column_name[:key] = value
my_model.column_name[:key]

哈希将使用YAML

序列化到列中

http://api.rubyonrails.org/classes/ActiveRecord/AttributeMethods/Serialization/ClassMethods.html#method-i-serialize