Mongoid中的日期查询

Bas*_*lah 8 ruby-on-rails mongodb mongoid

这已被问了很多,但我仍然面临一些问题.

我收到日期并存储为日期.我需要查询大于和小于,所以我将其更改为时间,再次尝试,但我得到了奇怪的结果.

我这样做

Class.where(:event_date.gt => Time.parse(Date.today))
Run Code Online (Sandbox Code Playgroud)

而我正在创造旧纪录,20世纪40年代,60年代和其他人.我尝试通过在最后添加.utc来转换时间,仅与Date.today进行比较,但到目前为止还没有解决问题.这是Mongoid生成的选择器

selector: {:date_utc=>{"$gte"=>Sat Sep 10 21:00:00 UTC 2011}},
Run Code Online (Sandbox Code Playgroud)

我以"2011-09-11"格式收到日期并将其存储在时间字段中.尝试解析时间utc,没有运气.

任何的想法?我正在使用Mongoid 2.0.2.以后的版本似乎与我正在使用的其他扩展不兼容.

[UPDATE]

所以问题在于1970年之前的旧日期显然.我现在的问题是如何处理它们.

Jav*_*ero 2

这是 Mongo 中的一个已知错误。参见第 405 期

原因是 Mongo 使用无符号数字来存储日期,因此纪元之前的任何内容都会滚动到遥远的未来。

幸运的是,今天发布的稳定版本 2.0 已经修复了这个问题。升级到此版本应该可以解决您的问题。