`
bellstar
  • 浏览: 151118 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

rails查询学习笔记

阅读更多
教程原文http://guides.rubyonrails.org/active_record_querying.html
1、获取数据
.获取第一条、最后一条记录
Model.first
Model.first(options)
Model.find(:first, options)

Model.last
Model.last(options)
Model.find(:last, options)


.通过id获取记录
Model.find(1, 10, options)
Model.find([1, 10], options)


.find all
Model.all(options)



.对一组数据进行相同操作
User.all.each do |user|
	NewsLetter.weekly_deliver(user)
end

如果表记录数比较大,这种方式比较耗资源,因为它会一次载入整个表的数据。改用以下这种方式,它每次只载入1000行,然后逐步yield完整个表
User.find_each do |user|
	NewsLetter.weekly_deliver(user)
end

自定义方式,find_each接受和find同样的options
User.find_each(:batch_size => 5000, :start => 2000) do |user|
	NewsLetter.weekly_deliver(user)
end

find_in_batches,和find_each相似,但它yield时传递的是model对象数组,而不是单个model对象
Invoice.find_in_batches(:include => :invoice_lines) do |invoices|
	export.add_invoices(invoices)
end


2、查询条件
通过替换?来传递条件值,可避免SQL注入
Client.first(:conditions => ["orders_count = ?", params[:orders])


symbol占位条件
Client.all(:conditions => ["created_at >= :start_date AND created_at <= :end_date", {:start_date => params[:start_date], :end_date => params[:end_date] }])



范围条件 in(集合)
Client.all(:conditions => ["created_at IN (?)", (params[:start_date].to_date)..(params[:end_date].to_date])

生成sql
SELECT * FROM users WHERE (created_at IN ('2007-12-31','2008-01-01','2008-01-02','2008-01-03','2008-01-04','2008-01-05', '2008-01-06','2008-01-07','2008-01-08'))

如果要生成日期时间,再加上.to_time
params[:start_date].to_date.to_time,生成2007-12-01 00:00:00格式

有上数据库会在以上条件中报错,如Mysql会报查询语句过长的错误,此时可以改成created_at > ? AND created_at < ?的形式

Hash条件
Client.all(:conditions => {:locked => true }) 


带范围条件
Client.all(:conditons => {:created => (Time.now.midnight - 1.day)..Time.now.midnight})

生成sql
SELECT * FROM clients WHERE (clients.created_at BETWEEN '2008-12-21 00:00:00' AND '2008-12-22 00:00:00')


集合条件
Client.all(:conditons => {:orders_count => [1,3,5])

生成sql
SELECT * FROM clients WHERE (clients.orders_count IN (1,3,5)) 


3、查询选项
排序
#单个排序
Client.all(:order => "created_at ASC")
#多个排序
Client.all(:order => "orders_count ASC, created_at DESC")


返回指定字段
Client.all(:select => "viewable_by, locked")
#使用函数
Client.all(:select => "DISTINCT(name)")


限定和偏移Limit and Offset
Client.all(:limit => 5)
#生成
SELECT * FROM clients LIMIT 5
Client.all(:limit => 5, :offset => 5)
#生成
SELECT * FROM clients LIMIT 5, 5


Group分组
Order.all(:group => "date(created_at)", :order => "created_at")

生成sql
SELECT * FROM orders GROUP BY date(created_at)


Having
Order.all(:group => "date(created_at)", :having => ["created_at > ?", 1.month.ago)

生成sql
SELECT * FROM orders GROUP BY date(created_at) HAVING created_at > '2009-01-15' 


只读
client = Client.first(:readonly => true)
client.locked = false
client.save
#对只读对象进行保存将会触发ActiveRecord::ReadOnlyRecord异常


更新时锁定记录
乐观锁Optimistic Locking
为使用乐观锁,须在表里建一个lock_version的字段,每次更新记录时,ActiveRecord自动递增lock_version的值,
c1 = Client.find(1) c2 = Client.find(1) c1.name = "Michael" c1.save c2.name = "should fail" c2.save # Raises a ActiveRecord::StaleObjectError 

备注:You must ensure that your database schema defaults the lock_version column to 0.

This behavior can be turned off by setting ActiveRecord::Base.lock_optimistically = false.

指定乐观锁字段名
class Client < ActiveRecord::Base set_locking_column :lock_client_column end 



悲观锁Pessimistic Locking
悲观锁定由数据库直接提供
Item.transaction do 
	i = Item.first(:lock => true)
	i.name = 'Jones'
	i.save
end

Mysql执行返回
SQL (0.2ms) BEGIN Item Load (0.3ms) SELECT * FROM `items` LIMIT 1 FOR UPDATE Item Update (0.4ms) UPDATE `items` SET `updated_at` = '2009-02-07 18:05:56', `name` = 'Jones' WHERE `id` = 1 SQL (0.8ms) COMMIT

为特定数据库加入原始的lock声明
为Mysql的锁定声明为共享模式,即锁定时仍然可读
Item.transaction do  i = Item.find(1, :lock => "LOCK IN SHARE MODE")  i.increment!(:views) end

4、关联表
Client.all(:joins => "LEFT OUTER JOIN address ON addresses.client_id = clients.id')

生成sql
SELECT clients.* FROM clients LEFT OUTER JOIN addresses ON addresses.client_id = clients.id 


使用Array、Hash、Named Associations关联表
有如下model
class Category < ActiveRecord::Base 
	has_many :posts 
end 
class Post < ActiveRecord::Base 
	belongs_to :category  
	has_many :comments  	
	has_many :tags 
end 
class Comments <ActiveRecord::Base 
	belongs_to :post  
	has_one :guest 
end 
class Guest < ActiveRecord::Base 
	belongs_to :comment 
end 



#关联一个关系
Category.all :joins => :posts
#关联多个关系
Post.all :joins => [:category, :comments] 
#嵌套关联
Category.all :joins => {:posts => [{:comments => :guest}, :tags]} 


为关联查询结果设定条件
time_range = (Time.now.midnight - 1.day)..Time.now.midnight Client.all :joins => :orders, :conditions => {'orders.created_at' => time_ran
#或者
time_range = (Time.now.midnight - 1.day)..Time.now.midnight Client.all :joins => :orders, :conditions => {:orders => {:created_at => time_range}} 


5、优化载入
以下代码,需要执行1 + 10次sql
clients = Client.all(:limit => 10) clients.each do |client| 
	puts client.address.postcode 
end 

优化:
clients = Client.all(:include => :address, :limit => 10) 
clients.each do |client| 
	puts client.address.postcode 
end 


一次性载入post的所有分类和评论
Post.all :include => [:category, :comments] 


载入category为1的所有post和cooment及tag
Category.find 1, :include => {:posts => [{:comments => :guest}, :tags]} 


6、动态查询
Client.find_by_name("Ryan")
Client.find_all_by_name("Ryan")

#!方法,没有记录时抛出ActiveRecord::RecordNotFound异常
Client.find_by_name!("Ryan")

#查询多个字段
Client.find_by_name_and_locked("Ryan", true)

#查询不到时就创建并保存
Client.find_or_create_by_name(params[:name])
#查询不到时创建一个实例,但不保存
Client.find_or_initialize_by_name('Ryan')


7、find_by_sql
Client.find_by_sql("SELECT * FROM clients INNER JOIN orders ON clients.id = orders.client_id ORDER clients.created_at desc") 


8、select_all
和find_by_sql类似,但不会用model实例化返回记录,你会得到一个hash数组
Client.connection.select_all("SELECT * FROM clients WHERE id = '1'") 


9、判断记录是否存在
#通过id来查询
Client.exists?(1)

Client.exists?(1, 2, 3)
#or
Client.exists?([1,2,3])

#通过其他条件来查询
Client.exists?(:conditions => "first_name = 'Ryan'")

#没有参数时,则:表是空的 ? false : true
Client.exists?


10、计算

#求结果集条数
Client.count(:conditons => "first_name = 'Ryan'")

#求某个字段非空白的条数
Client.count(:age)

#平均值
Client.average("orders_count")

#求最小值
Client.minimum("age")

#求最大值
Client.maximum("age")

#求和
Client.sum("orders_count")
分享到:
评论

相关推荐

    rails _sunspot 学习笔记

    1. **Ruby on Rails 3**:本文档主要针对 Rails 3 版本。 2. **Solr**:全文检索引擎,Sunspot 依赖于 Solr 来实现其功能。 3. **Sunspot gem**:Sunspot 的核心 gem,通过这个 gem 可以轻松配置和使用 Sunspot 功能...

    ruby on rails 笔记(陈刚)

    陈刚的Ruby on Rails学习笔记不仅提供了从零开始构建Rails项目的步骤指南,还深入浅出地讲解了MVC架构的基本原理,对于初学者来说是一份非常实用的参考资料。通过实践“Hello World”程序,读者可以亲身体验Rails的...

    ruby on rails环境搭建学习笔记;passenger+nginx环境配置

    ### Ruby on Rails 环境搭建与 Passenger+Nginx 配置详解 #### 一、Ruby on Rails 开发环境搭建 在进行 Ruby on Rails 的开发之前,首先需要完成一系列的基础软件安装工作,包括但不限于 Ruby 语言环境、Rails ...

    Ruby_On_Rails笔记

    综上所述,Ruby on Rails的笔记内容涵盖了从安装Rails环境到创建和运行一个简单的Rails项目的基础知识,这些内容对于初学者来说是学习Rails框架的极好入门材料。通过对这些知识点的学习,初学者可以快速了解Rails的...

    Ruby_on_Rails笔记

    通过阅读《Ruby on Rails笔记》,我们可以了解到作者对于Ruby on Rails学习过程中的深入理解和实践经验。这份笔记不仅是一份学习指南,也是对Rails初学者来说非常有价值的参考资料。无论是想要从零开始学习Rails,...

    web敏捷开发rails笔记

    通过以上内容的学习,我们了解了Rails的基本环境搭建、应用创建、控制器与视图的关系、动态内容的展示方式以及敏捷开发的思想。Rails以其高效简洁的特点,成为了Web开发领域的重要工具之一。掌握Rails不仅能够提高...

    rails_入门详细笔记(官网翻译).

    ### Rails 入门详细笔记知识点解析 #### 一、环境搭建 在开始使用 Rails 进行开发之前,首先需要确保你的开发环境满足以下条件: - **Ruby 版本**:推荐使用 Ruby 1.9.2 或更高版本。这是因为早期版本如 1.8.7 ...

    ROR 学习笔记系列一 Windows XP下环境安装配置(2)

    在本篇ROR(Ruby on Rails)学习笔记中,我们将深入探讨如何在Windows XP操作系统上进行环境的安装和配置。Ruby on Rails是一个流行的开源Web应用框架,它基于Ruby编程语言,以其“DRY”(Don't Repeat Yourself)...

    ruby on rails 实践

    作者鼓励读者在学习过程中注册GitHub账号,建立学习笔记仓库,以便与他人分享学习成果。书中的代码示例遵循特定的命名规则,比如命令使用小写,而作为名词时首字母大写。 《Ruby on Rails 实践》一书的著作权归作者...

    ICC学习笔记

    ICC学习笔记 ICC 学习笔记是一份详细的学习笔记,涵盖了 IC Compiler 的基础概念介绍,非常适合入门学习。该笔记中介绍了多个重要概念,包括 core ring、strap、macro ring、rail、track、trace、Gcell、Antenna ...

    Ruby On Rails开发从头来系列教程(chm)

    摘要:一直想尝试Ruby On Rails,但是因为对apache,mysql都不熟,对Rails的环境搭建更是没信心,所以一直没有开始,从知道了InstantRails后,终于在windows上搭建了Ruby On Rails开发环境,开始了Rails的学习。...

    Ruby on Rails心得

    陈刚撰写的《Ruby on Rails心得_V0.1》是一份非常宝贵的资料,旨在记录作者在学习Ruby on Rails过程中的所见所得,包括读书笔记、心得体会、自创教程及一些常见问题的解决方案。作者通过写作这种方式不仅加深了对...

    rubyinstaller-devkit-3.0.2-1-x64 and Ruby 学习笔记.7z

    总的来说,`rubyinstaller-devkit-3.0.2-1-x64 and Ruby 学习笔记.7z`文件包含了一个在Windows上开始Ruby编程所需的基本组件和学习资源。通过安装Ruby和DevKit,你可以轻松地编写、编译和运行Ruby代码,同时结合学习...

    后端语言的学习笔记.zip

    "后端语言的学习笔记.zip"这个压缩包很可能包含了关于各种后端编程语言的学习资源,特别是那些用于构建动态网站和Web服务的语言。尽管没有具体的标签提供额外信息,我们可以推测这可能涵盖了诸如Java、Python、Node....

    rails-study:学习滑轨

    笔记编程Ruby Ruby元编程 Ruby on Rails教程 敏捷Web开发Rails 5 附注4(21-24) 杂项Ruby其他注释Rails杂项说明上传文件说明注意事项Sidekiq注意Webpacker注意相关的其他项目及笔记: 资本主义研究耙研要学习: ...

    Ruby-on-Rails-101:Ruby on Rails 笔记摘自 WDI HKV 和其他来源。 比如,lynda的在线Rails教程

    本笔记摘录自WDI HKV以及lynda.com的在线Rails教程,旨在提供一个全面且深入的学习指南。 ### 1. **基础概念** - **MVC架构**:Rails采用Model-View-Controller(MVC)设计模式,将业务逻辑(Model)、用户界面...

Global site tag (gtag.js) - Google Analytics