gpt4 book ai didi

mysql - Rails 3.2 - ActiveRecord `where` 查询与调用属性的方法

转载 作者:太空宇宙 更新时间:2023-11-03 12:05:38 24 4
gpt4 key购买 nike

在控制台中我可以查询我的 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.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)

关于mysql - Rails 3.2 - ActiveRecord `where` 查询与调用属性的方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26764575/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com