我在公司模型中有一个序列化列:
class Company < ActiveRecord::Base
serialize :names
理想情况下,我希望它在数据库中存储这样的不同名称:
---
short: bestbuy
long: bestbuy ltd.
目前在我的公司#edit页面中,我有一个文本区域:
<%= f.text_area :names %>
如果我在数据库中有YAML,它将在浏览器中显示为:
{"short"=>"bestbuy", "long"=>"bestbuy ltd."}
但是,当我提交它时,它在数据库中成为:
--- ! '{"short"=>"bestbuy", "long"=>"bestbuy ltd."}'
题
我怎样才能使textarea显示YAML以供编辑人员编辑?
如何使数据库保存正确的YAML,而不是YAML和ruby哈希的混搭?
更新
如果我像这样强制列类型为Hash:
serialize :names, Hash
我尝试保存时会出错:
Admin :: CompaniesController#update中的ActiveRecord :: SerializationTypeMismatch
属性应该是哈希,但是是一个字符串
最佳答案 您可以使用原始SQL手动扫描数据库,但如果您还不知道自己在做什么,我不会推荐它.一个必然结果是你不应该乱用数据库的YAML版本,除非你已经确切地知道你正在做什么.
而是自己将数据转换为YAML:
@names = m.names.to_yaml
然后将@names填入您的< textarea>.然后保存已编辑的YAML,将其解析回Hash并将其移交给您的模型:
m.names = YAML.parse(params[:names])
# Or modify `params` in-place
params[:name] = YAML.load(params[:names])
# then stuff `params` into `m` as usual
为了安全起见,您应该指定您的名称应该是模型中的哈希值:
serialize :names, Hash
我不是serialize
的忠实粉丝所以我通常建议不要使用它;但是,如果要使用它,则应始终指定class_name以使其更安全.
您当前的方法是将Hash的to_s版本放入< textarea>:
{"short"=>"bestbuy", "long"=>"bestbuy ltd."}
那是一个字符串,而不是哈希;它可能看起来像一个哈希,但HTML不知道Ruby Hash是什么,所以它只是一个字符串.然后你读回来并把它放入名称,然后YAMLifies(作为一个字符串)到这个:
--- ! '{"short"=>"bestbuy", "long"=>"bestbuy ltd."}'
这是YAML中的一个字符串,这个字符串看起来很像哈希,但仍然是一个字符串.