我需要查询一天内的评论。该字段是标准时间戳的一部分,是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 =>["date(created_at) BETWEEN ? AND ? ", '2011-11-01','2011-11-15'])
我用的是3个点,而不是2个。三个点给你一个开始是开放的,结束是封闭的范围,所以如果你对后面的范围进行2次查询,你不能在两个范围中得到相同的行。
2.2.2 :003 > Comment.where(updated_at: 2.days.ago.beginning_of_day..1.day.ago.beginning_of_day)
Comment Load (0.3ms) SELECT "comments".* FROM "comments" WHERE ("comments"."updated_at" BETWEEN '2015-07-12 00:00:00.000000' AND '2015-07-13 00:00:00.000000')
=> #<ActiveRecord::Relation []>
2.2.2 :004 > Comment.where(updated_at: 2.days.ago.beginning_of_day...1.day.ago.beginning_of_day)
Comment Load (0.3ms) SELECT "comments".* FROM "comments" WHERE ("comments"."updated_at" >= '2015-07-12 00:00:00.000000' AND "comments"."updated_at" < '2015-07-13 00:00:00.000000')
=> #<ActiveRecord::Relation []>
而且,是的,使用瞄准镜总是很好的!
如果你只想休息一天,这样做会更容易:
Comment.all(:conditions => ["date(created_at) = ?", some_date])
有几种方法。你可以使用这个方法:
start = @selected_date.beginning_of_day
end = @selected_date.end_of_day
@comments = Comment.where("DATE(created_at) BETWEEN ? AND ?", start, end)
或:
@comments = Comment.where(:created_at => @selected_date.beginning_of_day..@selected_date.end_of_day)
我个人会创建一个范围,使其更具可读性和可重用性:
在你的评论中。Rb,你可以定义一个范围:
scope :created_between, lambda {|start_date, end_date| where("created_at >= ? AND created_at <= ?", start_date, end_date )}
然后到查询之间创建:
@comment.created_between(1.year.ago, Time.now)
希望能有所帮助。