ruby-on-rails – 时间gt查询无法在轨道上使用mongoid和ruby

我在轨道上使用mongoid和ruby.

我使用mongoid存储created_at时间

include Mongoid::Timestamps

所以,假设我有3个帖子就是这样创建的

{"post":"1","created_at": "2014-03-25 13:04:43"}
{"post":"2","created_at": "2014-03-25 13:04:44"}
{"post":"3","created_at": "2014-03-25 13:04:45"}

现在我想获得在{“post”:“2”}之后创建的所有帖子,即“2014-03-25 13:04:44”之后,这样只返回{“post”:“3” }

Model.where(:created_at.gt => "2014-03-25 13:04:44")

但是在上面的查询中它返回{“post”:“2”}和{“post”:“3”},所以{“post”:“2”}不应该在那里.

此.lt查询按预期工作.

任何想法为什么会这样?

提前致谢.

解决方法

问题出在时区…… mongoid created_at字段存储在UTC时区

你可以使用以下工作

Model.where(:created_at.gt => post_2_instance.created_at)

鉴于post_2_instance是{“post”:“2”,“created_at”:“2014-03-25 13:04:44”}

但如果要使用日期查询,可以使用以下内容

Model.where(:created_at.gt => DateTime.parse("2014-03-25 13:04:43").in_time_zone('UTC'))

奇怪的行为报告到@L_502_0@

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...