下面给大家演示一个在Rails中更加优雅地使用find
方法进行数据查询的方式。例子中Task
类有一个属性complete
表明任务是否已经完成(complete
字段是false
意味着未完成),incomplete
和last_incomplete
方法分别用来返回所有未完成的和最后一个未完成的任务。
ruby
class TaskController < ApplicationController def incomplete @tasks = Task.find(:all, :conditions => ['complete = ?', false]) end def last_incomplete @task = Task.find(:first, :conditions => ['complete =?', false], :order => 'created_at DESC') end end
更好的方式是将这句代码
ruby
@tasks = Task.find(:all, :conditions => ['complete = ?', false])
用这句来替换
ruby
@tasks = Task.find_all_by_complete(false)
如果想查找某一个Task
,使用find_by
。比如,查找最后一个未完成的任务将last_incomplete
方法中的这句代码
ruby
@task = Task.find(:first, :conditions => ['complete =?', false], :order => 'created_at DESC')
改为
ruby
@task = Task.find_by_complete(false, :order => 'created_at DESC')
find_by
方法可以像find
方法样接受order
参数。
转自:http://railscasts.com/episodes/2-dynamic-find-by-methods?language=zh&view=asciicast