繁体   English   中英

Rails 3.2-使用在属性上调用的方法的ActiveRecord`where`查询

[英]Rails 3.2 - ActiveRecord `where` query with method called on attribute

在控制台中,我可以像这样查询我的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 } Job.all.map { |j| j if j.created_at.year == 2014 } 如果我想收集需要在属性上调用方法的工作集合,那是最好的方法吗?

尝试这个:

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)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM