Rails 3.2 - ActiveRecord`where`查询方法调用on属性

时间:2014-11-05 18:36:58

标签: mysql ruby-on-rails ruby database activerecord

在控制台中,我可以像这样查询我的Job表:jobs = Job.where("created_at <= ?", Time.now)

我想获得今年创造的工作。如果我获得了单独的工作,我可以使用job.created_at.year,但如果我尝试使用jobs = Job.where("created_at.year = ?", 2014),我会收到以下错误:

SQLite3::SQLException: no such column: created_at.year

我想我明白问题是我试图将Ruby混合到SQL查询中,但我不确定如何解决它。理解这将有助于我创建更强大的ActiveRecord查询。

编辑 我发现我可以使用.map这样做:Job.all.map { |j| j if j.created_at.year == 2014 }。如果我想收集需要在属性上调用方法的作业集合,这是最好的方法吗?

1 个答案:

答案 0 :(得分:3)

试试这个:

Job.where(:created_at => Time.now.beginning_of_year..Time.now.end_of_year)

因为,调用Time.now可能会给出两个不同的年份(12月31日午夜之前和之后),最好先在当前时间创建一个变量,然后再在查询中使用它:

current_time = Time.now
Job.where(:created_at => current_time.beginning_of_year..current_time.end_of_year)