`
酷的飞上天空
  • 浏览: 522412 次
  • 性别: Icon_minigender_1
  • 来自: 无锡
社区版块
存档分类
最新评论

ActiveRecord学习

阅读更多

ActiveRecord是Rails进行数据库操作的核心组件。它采用标准的ORM模型,将表映射到类,将行记录映射到实例对象,将字段映射到对象的属性。

官方文档地址:http://api.rubyonrails.org/classes/ActiveRecord/Base.html

关联:http://api.rubyonrails.org/classes/ActiveRecord/Associations/ClassMethods.html

第一个简单例子

Rails的模型类都是继承自ActiveRecord::Base,这样该模型类就具有了对应数据库表的操作方法。默认情况模型类直接对应的表名应该是为下划线分割的复数形式,但也可以自行指定。

 如表users如下:

create table users(
   id int auto_increment primary key,
   username varchar(20),
   password varchar(20)
);

 

 

在model目录下创建user.rb,内容如下

class User < ActiveRecord::Base
end

 

这样就为表与User类建立起了映射关系。其中表的username对应User类的username属性,表的其他字段也同样在User中作为其对象属性。

 

为模型类指定映射的表名和主键

有时表名或主键是固定的不可能符合Rails的约定,那就只能手动指定类所对应的映射。

如:

class User < ActiveRecord::Base
set_table_name "users"
set_primary_key "id"
end

 

对model中的实例方法的复写,比如用于数据的转换或者校验

class User < ActiveRecord::Base
def password=(value)
if value.nil? or value.empty?
   raise "密码不能空!"
wirte_attribute "password",value
end
end

 

其中write_attribute()和read_attribute()这两个私有方法用于直接操作模型中的属性,所传递的参数是字符串类型,另外还可以使用Hash方式,如:self[:username]='''tttt"

 

数据的CRUD

数据的创建

使用new方法

u = User.new
u.username='lock'
u.password='123456'
u.save

 

或者create方法

User.create(:username=>'yea',:password=>'123456')
#或者传递一个Hash数组
User.create([{:username=>'name1',:password=>'123'},{:username=>'name2',:password=>'456'}])
#两种方式创建后都可以传递对象到一个代码块 
#User.create(:username=>'yee') do |u|
u.password='123456'
end

 

读取数据

#根据主键查找记录
User.find(1)
#根据主键数组,查找数据。返回一个数组
User.find(1,2,3) 或者User.find([1,2,3])
#以上查询如果没有记录则会抛出RecordNotFound的异常

#其他查询方法,使用例子如下
  # find first
  Person.find(:first) # returns the first object fetched by SELECT * FROM people
  Person.find(:first, :conditions => [ "user_name = ?", user_name])
  Person.find(:first, :conditions => [ "user_name = :u", { :u => user_name }])
  Person.find(:first, :order => "created_on DESC", :offset => 5)

  # find last
  Person.find(:last) # returns the last object fetched by SELECT * FROM people
  Person.find(:last, :conditions => [ "user_name = ?", user_name])
  Person.find(:last, :order => "created_on DESC", :offset => 5)

  # find all
  Person.find(:all) # returns an array of objects for all the rows fetched by SELECT * FROM people
  Person.find(:all, :conditions => [ "category IN (?)", categories], :limit => 50)
  Person.find(:all, :conditions => { :friends => ["Bob", "Steve", "Fred"] }
  Person.find(:all, :offset => 10, :limit => 10)
  Person.find(:all, :include => [ :account, :friends ])
  Person.find(:all, :group => "category")

 :conditions参数类似于SQL中的WHERE子句,指定查询中的条件。

:order 对返回的结果排序,类似于SQL中的ORDER BY

:group 分组,类似SQL中的 GROUP BY

:limit 指定返回结果的行数

:offset 指定结果的偏移量,表示从第几条符合条件的记录开始

:joins 类似于LEFT JOIN之类的自子语句,详情参阅官方文档

:include 根据表之间的关联,在查询中自动加入LEFT OUTER JOIN的SQL语句,详情参阅官方文档

:select 返回的字段,以字符串形式表示,如"id,name"。默认为select * ...

:from SELECT语句from后面的表名,默认为当前模型对应的表,可根据需要指定其他的表或视图

:readonly 标记返回的记录为只读,不能再被更细或保存

:lock 如::lock=>true  一个排它锁,通常用于在生产的sql语句中包含 for update子句,这样只有在事务提交后,锁才会被释放。

 

也可以直接使用sql,ActiveRecord提供个find_by_sql()方法,可以接受完整的sql语句进行查询。同时它也支持占位符的参数传递 如:

users = User.find_by_sql(['select * from users where username=?and password=?',username,password])

 

ActiveRecord还根据表的字段,动态生成了相应的查询简化相对应的查询方法。

users = User.find_by_username('jack')
users = User.find_by_password('123456')

 

更新数据

#给查询的对象重新赋值
u = User.find(1)
u.username = 'ttt'
u.save

#使用update_attribute()可以同时更新给定的特定字段的值,这种形式不再需要调用save方法
u = User.find(1)
u.update_attribute(:username=>'newname',:password=>'321654')

#使用类方法,update()和update_all(),update的第一个参数为更新的id。
User.update(1,:username=>'john',:password=>'123456')#更新ID为1的记录的username为john,password为123456
User.update_all("password='123'","username like '%j%'")#更改所有用户中用户名包含j的密码为123

 

删除数据

#第一种,调用对象的destroy方法
u = User.find(1)
u.destroy
#第二种,类方法delete()
User.delete(1)
User.delete([1,2,3])
#第三种,类方法delete_all(),它类似于SQL语句中DELETE语句的where
User.delete_all("username like '%j%'")

 

 

表间的关联

两表之间可能的关联分为三种:1.一对一关系2.一对多关系3.多对多关系。ActiveRecord提供了4个方法来表示表之间的关联:has_one、has_many、belongs_to和has_and_belongs_to_many

belongs_to

这个类方法表示从一个ActiveRecord对象到另外单个具有一个外键属性的被关联对象的关联方法。其选项有

:class_name 指定关联的类名,在关联名称不符合命名惯例的时候使用

:conditions 设置关联的约束条件

:foreign_key 指定用来查找关联对象的外键的列。一般情况下Rails会使用你所设的关联名称后面加_id的方法自动推算出外键的名称。

:counter_cache 这个选项让Rails自动更新被关联对象的从属对象数量。

:include 指定加载关联对象时同时要加载的关联对象,Rails会动态地在SELETE语句中加入必要的LEFT OUTER JOINS。

has_many

此关联允许你在一个数据模型中定义关联让他具有很多其他的附属的数据模型。选项有

:after_add 当一个记录通过<<方法被加入到集合中后会触发这个回调,但不会被集合的create方法触发。可以接受一个或多个方法名的符号或者Proc对象

:atfer_remove 当使用delete方法将一个记录从集合中移除时触发这个回调

:as指定被关联对象的多态belongs_to

:before_add 当一个记录通过<<方法被加入到集合之前触发这个回调,concat和push是<<的别名

:before_remove 当使用delete方法讲一个记录从集合中移除前触发回调

:class_name 当关联的类名不同于Rails自动推算出时,手动指定类名

:conditions 指定从数据库中取出对象的sql查询语句中加入额外的条件

:counter_sql  重载ActiveRecord自动生成的、用于统计关联中所包含的记录数量的sql。

:delete_sql 重载ActiveRecord自动生成的、用于取消关联的sql

:dependent=>:delete_all | :destroy_all | :nullify 其中delete_all使用单个sql语句删除被关联的对象,此方法不会触发被删除对象的任何destroy回调方法。destroy_all会逐个地调用被关联对象的destroy方法,将被关联的对象及父对象一起删除。nullity是默认选项,仅仅清除指向父对象的外键。

:finder_sql 指定一个完成的sql语句来读取关联,当关联非常复杂且需要依赖多个数据库表来获取数据时,可以利用这个选项

:foreign_key 重载ActiveRecord根据约定自动计算出的用于加载关联的sql语句中的外键名

:group 提供一个属性,计算结果自动根据这个属性进行分组,使用GROUP BY

:include 同belongs_to

:insert_sql 重载ActiveRecord自动生成的、用于创建关联的sql语句。

:limit 在自动生成的、用于加载关联的sql中加入一个limit

:offset 设置结果集的偏移量

:order 类似sql的ORDER BY

:select 指定查询的字段

:table_name  关联的表名

:uniq=>true 从关联的集合中剔除重复的对象

has_one

这个关联相对比较简单

:class_name 关联的类名

:conditions 关联的条件  v cg

:dependent 级联的操作

:foreign_key 关联的外键

:include 同上

:order 排序

 

校验

Rails的ActiveRecord提供了许多校验的辅助方法简化操作

validates_acceptance_of 确认表单的checkbox是否被标记

validates_associated 确认关联对象,每个关联对象的nil?法被调用

validates_confirmation_of 确认字段和指定字段的值是否有同样的内容

validates_each 确认块内的每个属性

validates_exclusion_of 确认指定的属性值不会出现在一个特定的可枚举对象中

validates_format_of 确认指定的属性值是否匹配由正则表达式提供的正确格式

validates_inclusion_of 确认指定的属性值是否是一个特定的可枚举对象中的一个有效值

validates_length_of 确定指定的属性值是否是匹配约束的长度 validates_length_of为其别名

validates_numericality_of 确认一个属性值是否是数字

validates_presence_of 确认指定属性值是否为空

validates_uniqueness_of 确定指定的属性在系统中是否唯一

默认信息的定义

:inclusion=>"is not included in the list"

:exclusion=>"is reserved"

:invalid=>"is invalid"

:confirmation=>"doesn't match confirmation"

:accepted=>"must be accepted"

:empty=>"can't be empty"

:blank=>"can't be blank"

:too_long=>"is too long(maxinum is %d characters)"

:too_short=>"is too short(mininum is %d characters)"

:wrong_length=>"is the wrong length(should be %d charscters)"

:taken=>"has already been taken"

:not_a_number=>"is not a number"

可以使用:message选项来重写默认的错误信息。

分享到:
评论

相关推荐

    Castle ActiveRecord学习实践

    ### Castle ActiveRecord 学习实践知识点总结 #### 快速入门指南 **概述:** Castle ActiveRecord 是 Castle Project 中的一个模块,用于提供对象关系映射 (ORM) 功能。它基于 NHibernate 构建,但简化了配置和使用...

    Castle ActiveRecord快速入门指南、ActiveRecord帮助文档

    - 提供的 `.chm` 文件是 Castle ActiveRecord 的官方帮助文档,包含了详细的功能说明、示例代码和故障排查指南,是学习和解决问题的重要资源。 通过以上介绍,你可以开始探索 Castle ActiveRecord 并将其应用于...

    NHibernate中文教程+activerecord

    **NHibernate 中文教程** NHibernate 是一个流行的开源对象关系映射(ORM)框架,用于.NET平台。ORM框架简化了数据库操作,通过将数据库表...通过学习和实践,您将能熟练地在.NET项目中运用ORM技术,提升开发效率。

    简单Castle.ActiveRecord.Generator

    Castle.ActiveRecord.Generator 是一个基于 Castle ActiveRecord 框架的代码生成工具...通过学习和使用 Castle.ActiveRecord.Generator,你可以更快地构建起一个功能完备的、基于ActiveRecord模式的数据驱动应用程序。

    C# Castle.ActiveRecord CS源码示例教程.zip

    通过深入学习和实践本教程提供的源码示例,开发者能够掌握 Castle.ActiveRecord 的基本用法和高级特性,提高开发效率,减少与数据库交互时的错误,并且更好地遵循面向对象的设计原则。同时,结合 Winform 的应用,...

    castle学习资料(自己整理,包含实例代码)

    Castle是针对.NET平台的一个开源项目,从数据访问框架ORM到IOC容器,再到WEB层的MVC框架、AOP,基本包括了整个开发过程中的所有东西,为我们快速...第一部分:ActiveRecord学习实践系列, 第二部分:Castle IOC容器系列

    ActiveRecord简单实例代码.zip

    通过学习和实践这些ActiveRecord的基本概念,开发者可以高效地进行数据库操作,同时减少与数据库的直接交互,提高代码的可读性和可维护性。在提供的压缩包"ActiveRecord简单实例代码"中,你可能会看到这些概念的具体...

    Ruby-OccamsRecord缺少ActiveRecord的高效查询API

    这对于需要优化查询性能的开发者来说是一个有利的工具,但对那些不熟悉SQL的人来说可能学习曲线会比较陡峭。 在压缩包"occams-record-master"中,可能包含了Occam's Record库的源代码,包括README文件、示例代码和...

    Castle ActiveRecord 最全的入门CHM帮助文档

    总的来说,这份 CHM 帮助文档集是学习 Castle ActiveRecord 的宝贵资源,涵盖了从基础概念到高级特性的全面内容,对于希望掌握这个框架的.NET 开发者来说,是一本不可或缺的随身手册。通过深入学习和实践,你可以...

    Castle ActiveRecord帮助文档.rar

    学习这些文档可以帮助开发者有效地利用Castle ActiveRecord来构建高效、灵活且易于维护的.NET应用。了解如何定义ActiveRecord类,如何配置数据库连接,如何使用NHibernate查询语言,以及如何利用Castle的DI和动态...

    [其他类别]ActiveRecord简单实例_activerecord(ASP.NET源码).rar

    通过学习这个实例,开发者可以了解如何在ASP.NET环境中实现ActiveRecord模式,提高数据库操作的便利性,同时减少与数据库交互的代码量。这个模式特别适合于快速开发,因为它简化了数据库操作,让开发者更专注于业务...

    Castle ActiveRecord 手册

    这个手册是专为那些想要在.NET环境中利用Castle ActiveRecord进行数据库操作的学习者准备的。以下是对这个框架的一些关键知识点的详细介绍: 1. **ActiveRecord模式**:ActiveRecord模式将业务对象与数据库表映射,...

    Apress Pro ActiveRecord Databases with Ruby and Rails.pdf

    ### ActiveRecord在Ruby与Rails中的应用 #### 一、前言 《Pro ActiveRecord:Databases with Ruby and Rails》这本书深入...通过学习本书,开发者能够更加熟练地使用ActiveRecord来构建高效、可维护的Web应用程序。

    ASP.NET源码——ActiveRecord简单实例.zip

    总的来说,通过学习这个ASP.NET的ActiveRecord简单实例,你可以了解到如何在.NET环境中使用ORM工具来简化数据库交互,以及如何通过面向对象的方式来管理和操作数据。这有助于提升你的Web开发技能,使你能够更高效地...

    PetShop_Model_DAL.rar_CASTLE_Castle mod_activeRecord_castle d

    在这个PetShop的示例中,我们还可以学习到如何将Castle ActiveRecord与其他ASP.NET组件(如控制器、服务层)集成,以实现MVC架构。通过这种方式,我们可以清晰地划分职责,提高代码的可维护性和可扩展性。 总结来说...

    浅谈MyBatis-Plus学习之ActiveRecord.docx

    在 MyBatis-Plus(MP)中,ActiveRecord(AR)模式是一种强大的工具,它将对象与数据库表的关系紧密地绑定在一起,简化了数据库操作。AR 模式的核心思想是,一个 Java 类对应数据库中的一个表,类的实例对应表中的一...

    ASP.NET-[其他类别]ActiveRecord简单实例.zip

    通过学习这个实例,开发者可以了解如何在ASP.NET项目中应用ActiveRecord模式,提高开发效率,简化数据库操作,并且理解如何将业务逻辑与数据访问代码解耦。同时,这也是一种实践面向对象编程和ORM技术的好方式。不过...

    ASP源码—实现ActiveRecord数据查询更新 v1.0.zip

    ASP(Active Server Pages)是一种微软开发的服务器端脚本环境,用于创建动态交互式网页。...通过这个源码,开发者可以学习如何在ASP环境中应用ActiveRecord模式,从而提高数据库操作的便利性和代码的可读性。

    ActiveRecord简单实例_aspx开发教程.rar

    在这个“ActiveRecord简单实例_aspx开发教程”中,我们将探讨如何在ASP.NET环境中集成并使用ActiveRecord,以便于更高效、更直观地处理数据。 首先,让我们了解什么是ActiveRecord。ActiveRecord是模式设计中的一种...

Global site tag (gtag.js) - Google Analytics