Ruby on rails开发从头来(四十一)- ActiveRecord基础(存储结构化数据) - 编程入门网
Ruby on rails开发从头来(四十一)- ActiveRecord基础(存储结构化数据)时间:2011-12-04 博客园 Cure有时,能够在某个属性中直接存储任意的ruby对象是很方便的,一种办法就是Active Record支持序列化,将一个ruby对象变为一个YMAL字符串,并且将这个字符串存储到属性对应的数据库字段中。在数据库定义中,这个字段必须为text类型。 因为Active Record将数据库中的Char型和text型映射为ruby的string型,所以如果我们需要告诉Active Record使用序列化功能,例如,我们想知道某个客户进行的最后的5次消费,我们创建一个含有text类型字段的表来保存信息: create table purchases ( id int not null auto_increment, name varchar(100) not null, last_five text, primary key (id) ); 在转换这个表的Active Record类中,我们要使用serialize()声明,来告诉Active Record要排列对象: class Purchase < ActiveRecord::Base serialize :last_five # ... end 当我们创建了一个新的Purchase对象,我们可以给last_five列赋任何值,在这个例子里,我们给last_five列设置一个字符串数组, purchase = Purchase.new purchase.name = "Dave Thomas" purchase.last_five = [ ''shoes'', ''shirt'', ''socks'', ''ski mask'', ''shorts'' ] purchase.save 当我们读入它的时候,这个属性已经被设置为数组: purchase = Purchase.find_by_name("Dave Thomas") pp purchase.last_five pp purchase.last_five[3] 代码的输出为: ["shoes", "shirt", "socks", "ski mask", "shorts"] "ski mask" 尽管这个功能是很强大且便利的,但是只有当你不打算在ruby以外的项目中使用这些序列化的信息,除非那个程序也能够使用YMAL格式。特别是,这些信息很难被SQL查询所利用,你也许会考虑使用聚合(aggregation)来替代,在后面我们会介绍这种办法来达到相同的效果。 |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |