使用Active Record

###ActiveRecord 作为rails中的ORM(object relation-db mapping)框架,ActiveRecord在初次出现之时带给了人们以无限的惊喜和热情,也使得很多不堪忍受其他语言中粗糙的ORM框架的开发者转而投入rials的怀抱。而有很多的其他语言也在不断尝试模仿ActiveRecord,比如著名的php框架codeigniter。 在rails的后期版本中,ActiveRecord可以作为一个独立的库来在rails之外使用,这对使用ruby进行其他数据库应用开发的用户来说非常方便。 ####在新的项目中使用ActiveRecord 如果在一个全新的rails应用程序中使用ActiveRecord,那么关于数据库方面的一切都可以托管给它,开发者在初期可能连一行代码都不需要编写就可以让程序“像模像样”的运行起来。 ####在已有的数据库上使用ActiveRecord 现实世界中,最可能遇到的问题是数据库已经存在了(毕竟,对于关系型数据库而言,修改schema的影响太大)。这时候,我们仍然可以使用ActiveRecord来方便的访问数据库,得到ruby对象,而跳过冗长且容易出错的数据库访问层。 ###一个例子 ####数据库结构 数据库中有一个访客表(visitor): +-----------------------+--------------+-----+ | Field | Type | Key | +-----------------------+--------------+-----+ | visitor_uid | varchar(32) | PRI | | visitor_login_id | varchar(128) | MUL | | visitor_password | varchar(32) | | | visitor_name | varchar(100) | | | created_timestamp | timestamp | | | password_expiration | timestamp | | | last_used_timestamp | timestamp | MUL | | visitor_alias | varchar(128) | MUL | | visitor_password_hash | binary(64) | | +-----------------------+--------------+-----+ 有一个访客浏览过的分组表(list_group):...

May 18, 2013 2 min