rubyonrails:Ruby on rails开发从头来( 4十一)- ActiveRecord基础(存储结构化数据)

  有时能够在某个属性中直接存储任意ruby对象是很方便种办法就是Active Record支持序列化个ruby对象变为个YMAL并且将这个串存储到属性对应数据库字段中在数据库定义中这个字段必须为text类型   Active Record将数据库中Char型和text型映射为ruby所以如果我们需要告诉Active Record使用序列化功能例如我们想知道某个客户进行最后5次消费我们创建个含有text类型字段表来保存信息:

create table purchases (
id not null auto_increment,
name varchar(100) not null,
last_five text,
primary key (id)
);


  在转换这个表Active Record类中我们要使用serialize声明来告诉Active Record要排列对象:

Purchase < ActiveRecord::Base
serialize :last_five
# ...
end


  当我们创建了个新Purchase对象我们可以给last_five列赋任何值在这个例子里我们给last_five列设置

purchase = Purchase.
purchase.name = "Dave Thomas"
purchase.last_five = [ 'shoes', 'shirt', 'socks', 'ski mask', 's' ]
purchase.save


  当我们读入它时候这个属性已经被设置为:

purchase = Purchase.find_by_name("Dave Thomas")
pp purchase.last_five
pp purchase.last_five[3]


  代码输出为:

["shoes", "shirt", "socks", "ski mask", "s"]
"ski mask"


  尽管这个功能是很强大且便利但是只有当你不打算在ruby以外项目中使用这些序列化信息除非那个也能够使用YMAL格式特别是这些信息很难被SQL查询所利用你也许会考虑使用聚合(aggregation)来替代在后面我们会介绍这种办法来达到相同效果

Tags:  rubyonrails安装 rubyforrails rubyrails rubyonrails

延伸阅读

最新评论

发表评论