Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/mongodb/13.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mongodb 边缘案例Mongo日期查询失败_Mongodb - Fatal编程技术网

Mongodb 边缘案例Mongo日期查询失败

Mongodb 边缘案例Mongo日期查询失败,mongodb,Mongodb,我对边缘案例周围的日期范围缺乏准确性感到困惑。我有一些文档的日期总是从一天的最开始开始-小时/分钟/秒00:00:00-我无法使用$gte操作符查询它们 > db.days.find({dateR : {$gte:new Date(2013,9,14)}},{dateR:1}) null > db.days.find({dateR : {$gte:new Date(2013,9,13)}},{dateR:1}) { "_id" : ObjectId("525b79b5c598c6f

我对边缘案例周围的日期范围缺乏准确性感到困惑。我有一些文档的日期总是从一天的最开始开始-小时/分钟/秒00:00:00-我无法使用$gte操作符查询它们

> db.days.find({dateR : {$gte:new Date(2013,9,14)}},{dateR:1})
null

> db.days.find({dateR : {$gte:new Date(2013,9,13)}},{dateR:1})
{ "_id" : ObjectId("525b79b5c598c6f439000600"), "dateR" : ISODate("2013-10-14T00:00:00Z") }

为什么在第二次查询中找到的文档没有出现在第一次查询中?

发生这种情况是因为
新日期(2013,9,14)
根据本地时区创建日期,但MongoDB日期始终为UTC

这应该起作用:

db.days.find({dateR:{$gte:newdate(Date.UTC(2013,9,14))},{dateR:1})

当我在我的机器上测试时,它工作正常。您会添加完整的代码包括数据插入吗?第一个响应有些可疑。如果mongodb没有找到任何东西,它不会在控制台上显示
null
,至少不会显示我在这里安装的任何版本。此外,像@EveryEvery一样,我无法重现这个问题。为了清晰起见,我插入了空值,但它显然对我不利。:)@强尼是对的。这是一个时区问题。