2013-06-25 170 views
0

我想在我的本地机器来执行使用吗啡在MongoDB的简单查询,查询的MongoDB发行其工作正常,但在另一台机器它不工作,
这是我的查询了日期范围

List<Ino> ino = ds.find(Ino.class).field("g_id").hasAnyOf(gId).field("iDate").greaterThanOrEq(stDate)  
.field("iDate").lessThan(inoEnd).asList() 

stDate和inoEnd是

Tue Jan 01 16:36:37 IST 2013 , Wed Jan 30 16:36:37 IST 2013 

上面的查询将返回空列表,但是当我使用以下奎雷斯尝试它,它做工精细

List<Ino> ino = ds.find(Ino.class).field("g_id").hasAnyOf(gId).field("iDate").greaterThanOrEq(stDate).asList() 

这将返回

[Ino(_id=926, g_id=27, iDate=Mon Jan 14 00:00:00 IST 2013), 
    Ino(_id=1026, g_id=27, iDate=Thu Feb 14 00:00:00 IST 2013), 
    Ino(_id=1110, g_id=27, iDate=Thu Mar 14 00:00:00 IST 2013)] 

,然后我试图

List<Ino> ino = ds.find(Ino.class).field("g_id").hasAnyOf(gId).field("iDate").lessThan(inoEnd).asList() 

这将返回

[Ino(_id=926, g_id=27, iDate=Mon Jan 14 00:00:00 IST 2013)] 

在我的本地和其他机器只有不同的是数据表示
这是怎么了我的地方收藏品是

{ "_id" : 926, "className" : "test", "g_id" : 27, "iDate" : ISODate("2013-01-14T18:30:00Z")} 

但在其他机器收集

{ "_id" : 926, "className" : "test", "g_id" : 27, "iDate" : "Mon Jan 14 2013 00:00:00 GMT+0530 (IST)"} 

那么可以之所以说上面的第一个查询结果为空?

+0

我本地蒙戈版本是MongoDB shell的版本:1.6.3 其他机器(这是不工作的)mongo版本是MongoDB shell版本:1.6.5,它可以是一个问题吗? – user1573690

回答

0

最后我克服了一个解决方案,但我仍然不知道什么是错的,我更新monogDB版本2.4.4 2.1,那么一切都按我预期

感谢