我有一个哈希:
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
我想这是由于时间字符串中的冒号所致。 那么,保持哈希并再次检索它的最佳方法是什么?
帮助表示赞赏。 最好, 菲利普
答案 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
序列化到列中