我需要查询一天内的评论。该字段是标准时间戳的一部分,是created_at。所选日期来自date_select。
我怎么用ActiveRecord来做呢?
我需要这样的东西:
"SELECT * FROM comments WHERE created_at BETWEEN '2010-02-03 00:00:00' AND '2010-02-03 23:59:59'"
我需要查询一天内的评论。该字段是标准时间戳的一部分,是created_at。所选日期来自date_select。
我怎么用ActiveRecord来做呢?
我需要这样的东西:
"SELECT * FROM comments WHERE created_at BETWEEN '2010-02-03 00:00:00' AND '2010-02-03 23:59:59'"
当前回答
您可以使用下面的gem来查找日期之间的记录,
这个宝石很容易使用和更清楚的由星我使用这个宝石和API更清楚和文档也很好地解释了。
Post.between_times(Time.zone.now - 3.hours, # all posts in last 3 hours
Time.zone.now)
在这里你可以通过我们的领域也Post。by_month("January", field::updated_at)
请查看文档并尝试一下。
其他回答
这段代码应该为你工作:
Comment.find(:all, :conditions => {:created_at => @selected_date.beginning_of_day..@selected_date.end_of_day})
要了解更多信息,请查看时间计算
注意:此代码已弃用。如果您使用的是Rails 3.1/3.2,请使用答案中的代码
如果你只想休息一天,这样做会更容易:
Comment.all(:conditions => ["date(created_at) = ?", some_date])
我运行了这段代码,看看选中的答案是否有效,并且不得不尝试交换日期以获得正确的答案。这个工作,
Day.where(:reference_date => 3.months.ago..Time.now).count
#=> 721
如果您认为产出应该是36,那么考虑一下,先生,3天对3个人来说是多少天?
Comment.find(:all, :conditions =>["date(created_at) BETWEEN ? AND ? ", '2011-11-01','2011-11-15'])
我认为应该有一个默认的活动记录行为。查询日期很困难,特别是涉及到时区时。
总之,我用:
scope :between, ->(start_date=nil, end_date=nil) {
if start_date && end_date
where("#{self.table_name}.created_at BETWEEN :start AND :end", start: start_date.beginning_of_day, end: end_date.end_of_day)
elsif start_date
where("#{self.table_name}.created_at >= ?", start_date.beginning_of_day)
elsif end_date
where("#{self.table_name}.created_at <= ?", end_date.end_of_day)
else
all
end
}